Transport for Los Angeles, US API

⭐ Beginner's Pick Transportation / No Auth Required Beginner HTTPS
Free to Use Varies (check documentation)

Overview

The LA Metro API provides real-time positions of Metro buses and trains across Los Angeles, along with route and schedule data. It requires no API key, so you can start making requests immediately without any registration. This is a great API for learning how to work with real-time vehicle tracking and public transit data.

💡

Beginner Tip

Begin by fetching all active vehicle positions from the /vehicles endpoint to see buses and trains moving in real time. Combine latitude and longitude values with a mapping library like Leaflet to build a live transit map.

Available Data

match scores and results
team standings
player statistics
schedule and fixtures
vehicle make and model
year and specifications

Example Response

JSON Response
{
  "route": "Line 1",
  "origin": "Station A",
  "destination": "Station B",
  "departure": "08:30",
  "arrival": "09:15",
  "status": "On Time",
  "delays_min": 0
}

Field Reference

id Unique identifier of the vehicle, typically the bus or train number.
latitude Current latitude of the vehicle, updated in near-real-time as the vehicle moves.
longitude Current longitude of the vehicle.
heading Direction the vehicle is traveling in degrees (0 = north, 90 = east, etc.).
route_id The route the vehicle is currently operating on, such as 720 or 805.
seconds_since_report How many seconds have passed since the vehicle last reported its position; lower values mean fresher data.

Implementation Example

// ⚠️ Note: This URL may be a documentation page. Check official docs for actual API endpoint.
const url = "https://developer.metro.net/api/";
const response = await fetch(url);
if (!response.ok) throw new Error(`Request failed: ${response.status}`);
const data = await response.json();
console.log(data);

What Can You Build?

Note: These code examples are AI-generated and unverified. Always refer to the official API documentation for accurate usage.

Common Errors & Troubleshooting

Empty vehicles array No vehicles are actively reporting at that moment, which can happen during very early morning hours.
Try the request during normal service hours (roughly 5 AM to midnight) and check the Metro service alerts page for outages.
CORS error in the browser The API may not send permissive CORS headers for all endpoints when called directly from a browser.
Make requests from a backend server (Node.js, Python, etc.) instead of directly from client-side JavaScript.
404 on agency or route endpoint The agency slug or route ID in the URL path is incorrect.
Use the /agencies/ endpoint to list all valid agency slugs, then drill down to routes and vehicles using the returned identifiers.

Matrix Score Breakdown

🌐 Reachability 30/30
⚡ Speed 15/20
🔒 Security 15/15
🛠 Developer XP 15/20
✓ Reliability 7/15
Response Time 272ms

Fully tested on Apr 5, 2026

Technical Specifications

Auth No Auth
HTTPS REQUIRED
CORS UNKNOWN
Category Transportation
Difficulty Beginner
Verified: 2026-04-04

Similar APIs

View All →