Skip to main content

A comprehensive Python wrapper for the Ergast API.

Project description

Ergast-Py


GitHub Downloads

A comprehensive Python wrapper for the Ergast API. Built for easy use and functionality, Ergast-py aims to bring the Ergast API into the Python network as seemlessly as possible.

NOTE: Ergast-py is still in active development, so all features are experimental and subject to change. Differences may occur between what is documented in this README.md and what is actually available in Ergast-py

Command prompt example of how to use Ergast

What is Ergast?

Ergast is a free, experimental API for accessing motor-racing data, dating back to the beginning of World Championships in 1950. The website provides plenty of detail into how effective the API can be, and the many options that are available for data gathering using it.

Why should I use Ergast-Py?

Ergast-Py provides a clean, Python orientated wrapper for this API. It has been designed to remove the heavy lifting of handling the API formatting behind the scenes, allowing developers to easily access the data that is relevant to them. All the data is conformed into clean class code, allowing for users to keep a Python-centric mindset whilst developing.

How to install

Ergast-py is a pip package, so can be installed with the pip command:

pip install ergast-py

Usage

Once ergast-py is installed on your system you can then begin using the library in querying the ergast API. To begin, initialise an instance of the Ergast() class.

Note: Whilst the package is called ergast-py, you need to import ergast_py

import ergast_py

e = ergast_py.Ergast()

Queries can then be built up with function calls in a sequential manner. Once you've built up a query, finally define what data you wish to get using a get_xyz() function.

# http://ergast.com/api/f1/2008/5/results
race_results = e.season(2008).round(5).get_results()

# http://ergast.com/api/f1/drivers/massa
felipe_massa = e.driver("massa").get_driver()

# http://ergast.com/api/f1/current/constructorStandings/3
constructor_standings = e.season().standing(3).get_constructor_standings()

Structure and Types

Ergast-py has many models which allow the user to more effectively use and manipulate the data available to them through Ergast. All models of data are available through .models.xyz.

Available models in ergast-py
Name Description
AverageSpeed The average speed achieved during a fastest lap
Circuit Details about a Formula One circuit
ConstructorStanding A single constructor's representation in the standings
Constructor A Formula One constructor
DriverStanding A single driver's representation in the standings
Driver A Formula One driver
FastestLap A fastest lap achieved by a driver
Lap Details about a drivers lap
Location The position of a circuit
PitStop Details about a driver's pit stop
Race Full representation of a Formula One race
Result Details about a driver's result
Season Details about a Formula One season
StandingsList A list of standings; constructors or drivers
Status Details about the final status of a driver in a race
Timing Details about the timings of a driver during a lap

Query building

There are 3 types of query available in the Ergast() class. FILTER functions build up the query, by filtering down the data that you will receive. PAGING functions control the flow of data if there is excessive amounts, limiting it to not overflow the API. RETURN functions detail what type of data you're expecting back from the query.

The order of the builder functions is inconsequential, however the final function called should be a return function.

Ergast().{paging/filter}.{return}

More detail on the available functions within the Ergast() class is available below.

FILTER functions
Name Arguments Notes
season year: int If you call season with no arguments it will default to the current season
round round_no: int If you call round with no arguments it will default to the last round
driver driver: Driver
constructor constructor: Constructor
qualifying position: int Position at the end of qualifying
sprint position: int
grid position: int Position lined up on the grid
result position: int
fastest position: int Ranking in list of each drivers fastest lap
circuit circuit: Circuit
status status: int Must use statusId or string representation
standing position: int Position of Driver or Constructor in standing
lap lap_number: int
pit_stop stop_number: int
PAGING functions
Name Arguments
limit amount: int
offset amount: int
RETURN functions

NOTE: All the functions that return a single object will raise an Exception if your query is returning more than one item.

Name Return Type
get_circuits list[Circuit]
get_circuit Circuit
get_constructors list[Constructor]
get_constructor Constructor
get_drivers list[Driver]
get_driver Driver
get_qualifyings list[Race]
get_qualifying Race
get_sprints list[Race]
get_sprint Race
get_results list[Race]
get_result Race
get_races list[Race]
get_race Race
get_seasons list[Season]
get_season Season
get_statuses list[Status]
get_status Status
get_driver_standings list[StandingsList]
get_driver_standing StandingsList
get_constructor_standings list[StandingsList]
get_constructor_standing StandingsList
get_laps list[Race]
get_lap Race
get_pit_stops list[Race]
get_pit_stop Race

Credits

This library would not be possible without the freely available Ergast API. For full information about the API and it's responsible use, please refer to their website. Poetry was used for package building and releasing.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ergast_py-1.0.0.tar.gz (30.6 kB view details)

Uploaded Source

Built Distribution

ergast_py-1.0.0-py3-none-any.whl (36.5 kB view details)

Uploaded Python 3

File details

Details for the file ergast_py-1.0.0.tar.gz.

File metadata

  • Download URL: ergast_py-1.0.0.tar.gz
  • Upload date:
  • Size: 30.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.4 Windows/10

File hashes

Hashes for ergast_py-1.0.0.tar.gz
Algorithm Hash digest
SHA256 fb5807c8ea01b13954f6393b0c4740f032d391ea7ae07cd17d9134ebf55974ee
MD5 de9a7e2806b5115d361e7b36d3191c93
BLAKE2b-256 c93df6c5947b635edc8615f84e28a139c0441ef638edfd82c74dd7b536db420b

See more details on using hashes here.

File details

Details for the file ergast_py-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: ergast_py-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 36.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.4 Windows/10

File hashes

Hashes for ergast_py-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fd52aeaefd696263fa83f1da830a2396f224867fa28c7c91ee1616b190e79324
MD5 23a01622a6e27cdbaeef0fdab7abc15c
BLAKE2b-256 2f2af80000ceddf5be8f87c86836836f211b681770acc70914200284b6d97ba9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page