Discover/procyclingstats.com API
live

procyclingstats.com APIprocyclingstats.com

Extract race results, team lists, and all-time victory rankings from ProCyclingStats. 3 endpoints covering stage races, one-day classics, and pro cycling teams.

Endpoints
3
Updated
3mo ago
Try it
The race URL path on ProCyclingStats (e.g. 'race/tour-de-france/2024/stage-1' or 'race/mil
api.parse.bot/scraper/cf66e8e3-c65a-4b3e-b418-c826000f01c2/<endpoint>
Ready to send
Fill in the parameters and hit sign in to send to see live response data here.
Use it in your codegrab a free API key at signup
curl -X GET 'https://api.parse.bot/scraper/cf66e8e3-c65a-4b3e-b418-c826000f01c2/get_race_results?url=race%2Ftour-de-france%2F2024%2Fstage-1' \
  -H 'X-API-Key: $PARSE_API_KEY'
All endpoints · 3 totalclick to expand

Extract detailed race metadata and results for a specific event (stage or one-day race). Returns race information such as date, distance, departure/arrival cities, and a full list of finishing positions with rider names, teams, times, and UCI points.

Input
ParamTypeDescription
urlrequiredstringThe race URL path on ProCyclingStats (e.g. 'race/tour-de-france/2024/stage-1' or 'race/milano-sanremo/2024').
Response
{
  "type": "object",
  "fields": {
    "results": "array of finishing positions, each with rank, rider_name, rider_url, team_name, uci_points, time, and resolved_time",
    "metadata": "object containing race details such as date, distance, departure, arrival, classification, profile_score, avg_speed_winner, and race_name"
  },
  "sample": {
    "data": {
      "results": [
        {
          "rank": "1",
          "time": "5:07:22",
          "rider_url": "https://www.procyclingstats.com/rider/romain-bardet",
          "team_name": "Team dsm-firmenich PostNL",
          "rider_name": "Bardet Romain",
          "uci_points": "210",
          "resolved_time": "5:07:22"
        }
      ],
      "metadata": {
        "date": "29 June 2024",
        "arrival": "Rimini",
        "distance": "206 km",
        "departure": "Firenze",
        "race_name": "2024 » 111th Tour de France (2.UWT)",
        "profile_score": "176",
        "classification": "2.UWT",
        "avg_speed_winner": "40.213 km/h"
      }
    },
    "status": "success"
  }
}

About the procyclingstats.com API

The ProCyclingStats API provides 3 endpoints for accessing professional cycling data including detailed race results, team rosters by year, and all-time career victory rankings. The get_race_results endpoint returns a full finishing list with rank, rider name, team, time, and UCI points for any stage or one-day race. Teams and rider statistics are available through the remaining two endpoints.

Race Results

The get_race_results endpoint accepts a url parameter pointing to any race path on ProCyclingStats — for example race/tour-de-france/2024/stage-1 for a stage or race/milano-sanremo/2024 for a one-day classic. The response includes a metadata object with fields such as date, distance, departure, arrival, classification, profile_score, and avg_speed_winner. The results array contains one entry per finisher, each carrying rank, rider_name, rider_url, team_name, uci_points, time, and resolved_time (elapsed time converted to a comparable format).

Teams and Victory Rankings

The get_all_teams endpoint accepts an optional year parameter (e.g. '2024') and returns an array of WorldTour and ProTeam entries, each with team_name and a two-letter country code. This is useful for building year-over-year team directories or filtering results by nation.

The get_victory_ranking endpoint takes no inputs and returns the top 100 riders ranked by all-time career victory count. Each entry includes rank, rider_name, and victories. The list is sorted descending by victory count and reflects cumulative career totals, not a single-season view.

Common use cases
  • Build a live race tracker that displays finishing positions, times, and UCI points for each stage of a Grand Tour.
  • Populate a cycling statistics dashboard with all-time career victory leaders using the get_victory_ranking response fields.
  • Generate year-over-year team composition reports by querying get_all_teams for multiple seasons.
  • Filter race results by team to analyse a squad's collective performance across a monument classic.
  • Map departure and arrival cities from race metadata to visualise route geography across a season.
  • Compare profile_score and avg_speed_winner fields across stages to identify the hardest races in a calendar year.
  • Build a UCI points tracker by aggregating uci_points per rider across multiple race result responses.
Pricing & limitsSee full pricing →
TierPriceCredits/monthRate limit
Free$0/mo1005 req/min
Hobby$30/mo1,00020 req/min
Developer$100/mo5,000250 req/min

One credit = one API call regardless of which marketplace API you call. Exceeding the rate limit returns a 429 response. Authenticate with the X-API-Key header.

Frequently asked questions
Does ProCyclingStats have an official developer API?+
ProCyclingStats does not publish an official public developer API or documented data feed. This API provides structured access to the data available on the site.
What does the `get_race_results` endpoint return for time fields, and how does `resolved_time` differ from `time`?+
The time field contains the raw time string as recorded in the results (e.g. a gap like '+0:32' for riders behind the winner). The resolved_time field converts that into an absolute elapsed time, making it easier to sort or compare finishers without manually parsing gap notation.
Does the API cover rider profile pages, career statistics, or individual race histories?+
Not currently. The API covers finishing results for specific races, team lists by year, and the all-time top-100 victory ranking. It does not expose individual rider profile pages or per-rider season histories. You can fork this API on Parse and revise it to add an endpoint targeting rider profile URLs.
Does `get_victory_ranking` return single-season victory counts or career totals?+
It returns all-time career victory totals. The endpoint takes no filter parameters, so it is not currently possible to scope results to a single season or race category through this endpoint. You can fork this API on Parse and revise it to add season-scoped or category-filtered victory endpoints.
Does `get_all_teams` include lower-division teams below WorldTour and ProTeam level?+
The endpoint covers WorldTour and ProTeam registered squads. Continental and national-level teams are not currently included in the response. You can fork this API on Parse and revise it to extend coverage to lower-division team listings.
Page content last updated . Spec covers 3 endpoints from procyclingstats.com.
Related APIs in SportsSee all →
athletic.net API
Search and analyze cross country and track & field performance data across the US, including athlete profiles, meet results, team rosters, and rankings. Access comprehensive meet information, historical records, and state-level competition data to track athlete progress and discover top performers.
maxpreps.com API
Access high school sports data from MaxPreps. Search for schools, retrieve team rosters and schedules, look up athlete profiles, and browse national or state rankings across all sports.
vg.no API
Access VG.no's latest news, articles, sports scores, and TV guides through a single interface where you can browse the front page, search articles by topic, view category-specific content, and find related stories. Get real-time sports scores and television schedules alongside comprehensive news coverage from Norway's leading news outlet.
vegasinsider.com API
Retrieve MLB betting odds from major sportsbooks including bet365, FanDuel, and DraftKings, covering Moneyline, Total, and Runline markets for any supported date. Easily compare odds across books to identify the best available lines.
puntoticket.com API
Browse and search events happening in Chile with PuntoTicket, viewing featured shows, filtering by category, and checking detailed pricing and availability for concerts, theater, sports, and more. Find the perfect event by exploring all listings or discovering what's trending right now.
130point.com API
Search for sold trading cards across eBay, Goldin, Heritage Auctions, Pristine Auction, MySlabs, and Fanatics Collect to find historical prices, sale dates, and marketplace information all in one place. Get comprehensive sales data to research card values and track market trends across multiple platforms instantly.
wynncraft.com API
Access detailed Wynncraft game information to look up item metadata and search across the complete item database, retrieve player statistics and character inventories, and browse guild information and global search results. Use this data to compare gear, track player progress, analyze guild rosters, or build tools for the Wynncraft community.
whoscored.com API
Search for players and teams, then dive deep into their performance metrics, match statistics, and detailed passing data to analyze football games and player abilities. Get comprehensive insights on team performance, individual player stats, and play-by-play event information to power your football analysis and decision-making.