Bug Reports

If you identify any API bugs or errors in the data please record them here.

Comments

812 responses to “Bug Reports”

  1. Admin Avatar
    Admin

    Thanks for the warning Latsi – now updated.
    Chris

  2. Luke Bassett Avatar
    Luke Bassett

    Hello,

    I found a few errors in the lap timing csv. I noticed these because of merge errors between the lap_times and results csv files.

    For the 1999 Brazillian GP:
    Laps are recorded for Badoer (driverId: 69) although he sat that race out for an injury. I believe these laps should belong to Stephane Sarrazin (driverId: 72).

    For 1997 European GP:
    I don’t believe Giannin Morbidelli (driverId: 81) participated in that race, although he has lap times attributed to him. I believe these laps should belong to Norberto Fontana (driverId: 82).

    For the 1999 San Marino GP, Monaco GP, and Spanish GP:
    Laps are attributed to Ricardo Zonta (driverId: 41), although he was out with at foot injury. Mika Salo (driverId: 63) raced these three races for BAR.

    Thank you so much for maintaining all this data, lots of fun to play with on weekends without races =D

    Regards,
    Luke

  3. Admin Avatar
    Admin

    Hi Luke,
    Thanks for the corrections – now updated.
    Chris

  4. Niclas Avatar
    Niclas

    Hi

    Thanks for the API, really nice to get F1 data and play around with.

    I’m fetching data with
    http://ergast.com/api/f1/current/last/results.json

    Details: Under Result, there is Driver, Constructor, Status, Time and FastesLap in xml response.

    But in the json response there is Driver, Constructor, Time and FastesLap…not Status.

    Regards
    Niclas

  5. Admin Avatar
    Admin

    Hi Niclas,
    Actually, the status is present in the JSON results – it’s the statusId which is missing. I’m not sure why I included the statusId in the XML – it may have been a mistake I corrected in the JSON!
    Chris

  6. Marco Avatar

    Hello!
    the team ranking seems to be wrong, the India force marks the fourth place, in fact, from the official site, after the change of company is at the seventh.
    Regards
    Marco

  7. Admin Avatar
    Admin

    Hi Marco,
    Thanks for the warning – I forgot to reset Force India’s points.
    Chris

  8. Marcus Avatar
    Marcus

    I have found 3 tiny ones.

    In one row of qualifying.csv q2 is ‘1:48:552’ instead of ‘1:48.552’:

    – 5665,891,3,131,9,4,”2:01.099″,”1:48:552″,”2:02.251″

    And in constructor_results.csv are two duplicates:
    – 612,75,7,11,\N
    – 14128,75,7,11,\N

    – 14845,903,3,6,\N
    – 14852,903,3,6,\N

  9. Marcus Avatar
    Marcus

    Hi,

    it’s pretty easy to get altitude for all circuits, btw: https://hastebin.com/ezenicikaf.makefile (In there is a prepared post request you can paste into your terminal.)

    Regards,
    Marcus

  10. Toby Avatar

    Hi Chris

    Possible the problem is at my end (unpacking the sql into pandas dataframes – although the process has always worked previously) but I am only seeing results to Russia from the disk image after Austin. Had no problem updating from the API though.

    Cheers
    Toby

  11. Admin Avatar
    Admin

    Hi Toby,
    I can see Kimi’s U.S. Grand Prix time in the SQL dump (1:34:18.643) but I guess there could be an issue elsewhere.
    I’ve re-run the dump script so it might be worth another try.
    Chris

  12. Admin Avatar
    Admin

    Thanks Marcus! Now corrected.
    Chris

  13. Marcus Avatar
    Marcus

    Hi Chris,

    your database really helps a lot while learning to write proper SQL queries. Unfortunately, I am not really knowing a lot about the history of F1… The constructorResultIds 14985, 14986, 14805, and 14806 are the only rows before 1958 that have points. Is that a bug?

    Regards,
    Marcus

    https://imgur.com/a/eSEfCdh

  14. Admin Avatar
    Admin

    Hi Marcus,
    Thanks – I’ll investigate. The constructorResults is an intermediate table, used in calculating the standings, and may not have been used when loading historical data from various sources.
    Chris

  15. Fattazzo Avatar

    Hi Chris,
    driverStandings and constructorStandings show wrong data.

    Example.

    Correct value: Vettel 320 points, Hamilton 408 points

    Calling https://ergast.com/api/f1/current/drivers/vettel/results.json the sum of points is 320

    Calling https://ergast.com/api/f1/current/driverStandings.json is 302

    With Hamilton result do 408 and standings do 383

    Regards,
    Gianluca

  16. Admin Avatar
    Admin

    Hi Gianluca,
    Apologies, I forgot to check. Now updated.
    Thanks for the warning.
    Chris

  17. Andrea Avatar
    Andrea

    Hi Chris,

    I think that the qualifying result are wrong.
    For example:
    https://ergast.com/api/f1/drivers/senna/grid/1/qualifying
    gives me 3 pole position while Senna made 65.

    https://ergast.com/api/f1/drivers/michael_schumacher/grid/1/qualifying?limit=100
    gives me 35 pole position while Schumacher made 68

    For Fangio no pole position (the correct value is 29).

    Theese problems also affect, for example, hat trick query.
    Can you check?

    Thanks in advance,
    Regards.

    Andrea

  18. Andrea Avatar
    Andrea

    Hi Chris,

    In addition to previous bug report, also fastest lap in race result is wrong.

    For example
    https://ergast.com/api/f1/drivers/senna/fastest/1/results?limit=100

    gives me 0 fastest lap while Senna made 19.

    I’ve done theese querys from your Uery Database Interface.

    Thnaks again.

    Andrea

  19. Admin Avatar
    Admin

    Thanks Andrea – will correct.
    Chris

  20. Admin Avatar
    Admin

    Hi Andrea,
    The problems with the qualifying is caused by the fact that qualifying information is only supported from 1994 onwards – after the start of Senna’s career unfortunately. Similarly Lap Time information is only supported from 1996 onwards. Unfortunately, it has been difficult to find earlier data.
    Chris

  21. Des Avatar
    Des

    Hi,
    What a great site for statistics but at the risk of sounding morbid the status of the following resultId’s should be amended from 3 to 104 as they were all fatal accidents. There are currently only 3 records with a 104 statusId.

    resultId Date Driver
    19125 30/05/1955 Bill Vukovich
    18571 30/05/1958 Pat O’Connor
    18613 06/07/1958 Luigi Musso
    18648 03/08/1958 Peter Collins
    18714 19/10/1958 Stuart Lewis-Evans
    18174 19/06/1960 Alan Stacey
    18177 19/06/1960 Chris Bristow
    18034 10/09/1961 Wolfgang von Trips
    16923 07/08/1966 John Taylor
    16637 07/05/1967 Lorenzo Bandini
    16488 07/07/1968 Jo Schlesser
    15987 21/06/1970 Piers Courage
    15189 29/07/1973 Roger Williamson
    15317 07/10/1973 François Cevert
    14469 17/08/1975 Mark Donohue
    13314 05/03/1977 Tom Pryce
    13183 10/09/1978 Ronnie Peterson
    11214 09/05/1982 Gilles Villeneuve
    5216 01/05/1994 Ayrton Senna
    5220 01/05/1994 Roland Ratzenberger
    22458 05/10/2014 Jules Bianchi

    Keep up the good work!
    Regards
    Des

  22. Simon Avatar
    Simon

    Hi,

    Awesome API, however I think your HTTPS certifcate has expired again as I am getting errors with HTTPS. It works with normal HTTP though.

    Thanks in advance,
    Simon

  23. Chris Thurgood Avatar

    FYI, today, in Xcode I got this error when trying to retrieve Drivers or Constructors data: “Error: [Optional(“An SSL error has occurred and a secure connection to the server cannot be made.”)]” I went to my phone to test my app and the data isn’t populating the screen anymore. Has your SSL expired? All was fine until a few days ago.

  24. Admin Avatar
    Admin

    Hi Chris,
    Apologies – the site cert expired. Now renewed.
    Chris

  25. Tony Hirst Avatar
    Tony Hirst

    The ANSI SQL file in the db download area “intended for things like sqlite” includes an “AUTO_INCREMENT” statement int he table definitions that SQLite chokes on (I think it expects AUTOINCREMENT ?).

    For generating a SQLIte conveniently from your MySQL master, something like https://github.com/simonw/db-to-sqlite might help? (And if it breaks, a raised issue may well lead to a fix in that package…)

  26. Admin Avatar
    Admin

    Hi Tony,
    IIRC the ANSI-compatible SQL dump was requested by someone who wanted to use db-to-sqlite. I can’t take responsibility for conversions but I’d be happy to amend the parameters for the mysqldump if it helps. The current parameters for the ANSI dump are:

    –default-character-set=utf8
    –compatible=ansi
    –skip-extended-insert
    –compact

    Chris

  27. Coen Verheijden Avatar
    Coen Verheijden

    Look like the database dumps and the csv dumped with conversion issues

    example:

    See below

    http://en.wikipedia.org/wiki/Aut%C3%B3dromo_Jos%C3%A9_Carlo

    But there are more example..

    iconv to UTF8 will not help

  28. Admin Avatar
    Admin

    Hi Coen,
    The example you give is truncated, rather than a conversion issue and looks ok in circuits.csv. Have you got any other examples?
    Chris

  29. Aleksander Avatar
    Aleksander

    Hello,

    I’ve just found that Robert Kubica is missing permanent number which is #88.

    Regards
    Aleksander

  30. Admin Avatar
    Admin

    Hi Aleksander,
    Ah yes – he didn’t have one in 2010!
    Thanks for the warning.
    Chris

  31. Jorge Gonzalez Avatar
    Jorge Gonzalez

    Antonio Giovinazzi current Permanent # should be his F1 #99 instead of the temporary #36

    http://ergast.com/api/f1/2019/drivers

    thanks

    Jorge

  32. Admin Avatar
    Admin

    Thanks Jorge – now corrected.

  33. Yoshi Avatar

    Hello,
    Incorrect data entry of RedBull and ToroRosso constructor points.

    Regards
    Yoshi

  34. Gabor Avatar
    Gabor

    Hello,

    Incorrect data entry of Norris start grid. Ricciardo and Norris got the same grid number(10). Norris(9), Ricciardo(10).

    Regards
    Gabor

  35. Admin Avatar
    Admin

    Thanks Gabor and Yoshi – now corrected.
    Chris

  36. Graeme Avatar
    Graeme

    Hi,

    I am using your (very awesome btw) API to do some F1 visualisation and also build a Tableau Web Connector to get the data.

    In looking at this, I have been calculating driver ages at the start of each season and noticed that there is one driver without a DoB – Ray Reed.

    I have a workaround to put it in place with a calculation using the DoB from his Wikipedia page to populate it but just wanted to let you know it was not in the DB.

    Again, keep up the amazing work with this – it is so comprehensive and a joy to work with.

    Graeme Ord – Tableau Developer

  37. Admin Avatar
    Admin

    Hi Graeme,
    Thanks for pointing this out – the date has been added.
    Cheers,
    Chris

  38. Mike Avatar

    Not so much a bug, but missing data. The results for the China GP have been added, but no Fastest Lap data is available.

    Thanks for the continued work on the awesome API 🙂

  39. Admin Avatar
    Admin

    Hi Mike,
    Unfortunately, the data hasn’t been published yet. Hope to add it in the next 24 hours.
    UPDATE: all data now available + new DB dump
    Cheers,
    Chris

  40. Davide Albiero Avatar
    Davide Albiero

    Hi, I think you need to rebuild the database regarding the lap section. The response time is very high. I took a look at how the database was designed and the table was designed really badly. I think you should split it or do something to solve this problem. Best Regards Davide

  41. Admin Avatar
    Admin

    Hi Davide,
    Suggestions on the table design and indexing would be very welcome. I’ve had previous complaints about performance, so the documentation page now says you should include a lap number in the query (but it still works without, albeit slowly).
    Chris

  42. Michal Avatar
    Michal

    Hi, the qualifying results for Baku should be updated with Kimi Raikonnen not being classified.

    Thank you for the API and service
    Michal

  43. Admin Avatar
    Admin

    Hi Michal,
    Thanks for the info now updated.
    Chris

  44. mkl Avatar
    mkl

    Hi, found some missing results and other misc. errors in the database.

    – in the 1961 US GP, Olivier Gendebien shared his drive with Masten Gregory – this is not reflected in the DB
    – in the 1964 US GP, Mike Spence shared his drive with Jim Clark – this is not reflected in the DB
    – Andrea de Adamich (DNF after 26 laps, between Soler-Roig and Peterson) is missing from the results of 1971 Spanish GP
    – at the final 2 races of the 1978 season (US, Canada), Rene Arnoux was driving #18 entry, not #31
    – Corrado Fabi is listed in the results of 1984 British GP – it was Teo Fabi who drove that race
    – finally, in the 2017 US GP, the driver numbers for Ferrari drivers are switched around

    If you want, I’ve got ready-made SQL statements to correct these: https://gist.github.com/emkael/7dc3e45504721f0b2fd01609577857aa

    Michal K.

  45. Admin Avatar
    Admin

    Thanks Michal – that’s really helpful!
    Cheers,
    Chris

  46. mkl Avatar
    mkl

    Some Q1/Q2 time corrections in qualifying table:

    – 2008 Bahrain GP: Vettel (qualifyId = 63) Q1 time should be 1:33.562
    – 2008 Bahrain GP: Sutil (qualifyId = 64) Q1 time should be 1:33.845
    – 1998 Brazilian GP: Magnussen (qualifyId = 1693) Q1 time should be 1:19.644
    – 1997 Brazilian GP: Panis (qualifyId = 1835) Q1 time should be 1:16.756
    – 2012 British GP: Karthikeyan (qualifyId = 5178) Q1 time should be 1:53.040
    – 2014 German GP: Bianchi (qualifyId = 6099) Q1 time should be 1:19.676
    – 2011 Monaco GP: Di Resta (qualifyId = 4669) Q2 time should be 1:16.118
    – 2013 Singapore GP: Raikkonen (qualifyId = 5718) Q2 time should be 1:44.658

    Here’s an SQL file: https://gist.github.com/emkael/8efbf656b1a442b14614ad204e2ed510

  47. Admin Avatar
    Admin

    Hi Gustavo,
    The default page limit is 30 entries, so Senna is in the second page of results:
    http://ergast.com/api/f1/1991/1/drivers.json?offset=30
    Alternatively you can increase the page size:
    http://ergast.com/api/f1/1991/1/drivers.json?limit=50
    Chris

  48. Berdy Avatar
    Berdy

    Hey, can you make it possible to provide lap times in seconds too? It will make working with the lap times way more easier when you have the choice between regular “0M:SS.SSS” format and a format that is more easily readable computer wise.

  49. Lenny Avatar
    Lenny

    In the 1950 Italian GP, Alberto Ascari raced for Ferrari not Alfa Romeo. http://ergast.com/api/f1/1950/7/results

Leave a Reply

Your email address will not be published. Required fields are marked *