Google Maps Directions API
The Google Maps Directions API returns route data for driving, transit, walking, cycling, and flying. Extract step-by-step directions with coordinates, travel times, distances, and service provider details. Flight results include ticket prices and direct booking links to Google Flights. Transit routes include schedules, station information, provider contacts, and ticket purchase links. Driving directions include toll warnings and traffic-optimized routing.
API Parameters
Search Query
-
- Name
-
from
- Required
- Required
- Description
-
Parameter defines the origin of the route. Can be a plain address, data ID, or coordinates (lat,long).
-
- Name
-
to
- Required
- Required
- Description
-
Parameter defines the destination of the route. Can be a plain address, data ID, or coordinates (lat,long).
-
- Name
-
waypoints
- Required
- Optional
- Description
-
Parameter defines the waypoints of the route. Should be an array where each element is a string that can be a plain address, data ID, or coordinates (lat,long).
Example:["0x40d8a9890932b5d5:0x8b7c49e19a7fc6a4", "Times Square, New York"]
Maximum 8 elements.
Note: This parameter is not supported whentravel_mode
is set totransit
.
Note: This parameter cannot be used together with thetime
parameter.
-
- Name
-
travel_mode
- Required
- Optional
- Description
-
Parameter defines the mode of travel. Allowed options are:
-
best
Default driving
cycling
walking
-
transit
Not supported whenwaypoints
is present flying
-
-
- Name
-
time
- Required
- Optional
- Description
-
Parameter defines the departure or arrival time for the route. Supports three formats:
depart_at:<timestamp>
- Departure time as Unix timestamparrive_by:<timestamp>
- Arrival time as Unix timestamp-
last_available
Only supported whentravel_mode
istransit
Note: This parameter cannot be used together with thewaypoints
parameter.
-
- Name
-
route
- Required
- Optional
- Description
-
Parameter defines the route preference for transit directions. Allowed options are:
-
best
Default fewer_transfers
less_walking
wheelchair_accessible
Note: This parameter is only supported whentravel_mode
is set totransit
. -
-
- Name
-
prefer
- Required
- Optional
- Description
-
Parameter defines the preferred transit types for transit directions. Should be an array where each element is a string representing a transit type preference. Allowed options are:
bus
subway
train
tram_and_light_rail
Example:["bus", "subway"]
Note: This parameter is only supported whentravel_mode
is set totransit
.
-
- Name
-
avoid
- Required
- Optional
- Description
-
Parameter defines what to avoid when calculating routes. Should be an array where each element is a string representing something to avoid. Available options:
-
tolls
- Avoid toll roads (Only available for driving and best modes) -
highways
- Avoid highways (Only available for driving and best modes) -
ferries
- Avoid ferries (Only available for walking and cycling modes)
Example:["tolls", "highways"]
(for driving mode) -
-
- Name
-
distance_units
- Required
- Optional
- Description
-
Parameter defines the unit of distance measurements in the response. Allowed options are:
-
automatic
Default km
- Kilometersmi
- Miles
Note: This parameter is not supported whentravel_mode
is set toflying
ortransit
. -
Localization
-
- Name
-
gl
- Required
- Optional
- Description
-
The default parameter
us
defines the country to use for the search. Check the full list of supported Googlegl
countries.
-
- Name
-
hl
- Required
- Optional
- Description
-
The default parameter
en
defines the interface language of the search. Check the full list of supported Googlehl
languages.
Engine
-
- Name
-
engine
- Required
- Required
- Description
-
Parameter defines an engine that will be used to retrieve real-time data. It must be set to
google_maps_directions
.
API key
-
- Name
-
api_key
- Required
- Required
- Description
-
The
api_key
authenticates your requests. Use it as a query parameter (https://www.searchapi.io/api/v1/search?api_key=YOUR_API_KEY
) or in the Authorization header (Bearer YOUR_API_KEY
).
Zero Data Retention
-
- Name
-
zero_retention
- Enterprise Only
- Enterprise Only
- Required
- Optional
- Description
-
Set this parameter to
true
to disable all logging and persistent storage. No request parameters, HTML, or JSON responses are stored or logged. Suitable for high-compliance use cases. Debugging and support may be limited while enabled.
API Examples
Full Response

https://www.searchapi.io/api/v1/search?engine=google_maps_directions&from=New+York&to=Chicago
- Python
- Node
- Ruby
- Java
- Go
- PHP
- Bash
- R
- Kotlin
- Swift
- C#
- C
- C++
- requests
import requests
url = "https://www.searchapi.io/api/v1/search"
params = {
"engine": "google_maps_directions",
"from": "New York",
"to": "Chicago"
}
response = requests.get(url, params=params)
print(response.text)
{
"search_metadata": {
"id": "search_DdeYJm72pz81tz5Qo9ZEPlbV",
"status": "Success",
"created_at": "2025-09-12T14:23:48Z",
"request_time_taken": 1.88,
"parsing_time_taken": 0.09,
"total_time_taken": 1.97,
"request_url": "https://www.google.com/maps/dir/New+York/Chicago%2C+Illinois",
"html_url": "https://www.searchapi.io/api/v1/searches/search_DdeYJm72pz81tz5Qo9ZEPlbV.html",
"json_url": "https://www.searchapi.io/api/v1/searches/search_DdeYJm72pz81tz5Qo9ZEPlbV"
},
"search_parameters": {
"engine": "google_maps_directions",
"from": "New York",
"to": "Chicago",
"travel_mode": "best",
"route": "best",
"distance_units": "automatic",
"gl": "us",
"hl": "en"
},
"travel_modes": [
{
"travel_mode": "Driving",
"formatted_duration": "12 hr",
"duration": 44087
},
{
"travel_mode": "Transit",
"formatted_duration": "20 hr",
"duration": 70800
},
...
],
"places_info": [
{
"address": "New York",
"data_id": "0x89c24fa5d33f083b:0xc80b8f06e177fe62",
"coordinates": {
"latitude": 40.7127753,
"longitude": -74.0059728
}
},
{
"address": "Chicago, Illinois",
"data_id": "0x880e2c3cd0f4cbed:0xafe0a6ad09c0c000",
"coordinates": {
"latitude": 41.88325,
"longitude": -87.6323879
}
}
],
"directions": [
{
"travel_mode": "Driving",
"via": "I-80 W",
"formatted_duration": "12 hr 10 min",
"duration": 43813,
"distance": 1271793,
"formatted_typical_duration": "11 hr 22 min to 14 hr 17 min",
"optimistic_duration": 40939,
"pessimistic_duration": 51408,
"formatted_distance": "790 miles",
"warnings": [
"This route has tolls.",
"Your destination is in a different time zone."
],
"instructions": [
{
"travel_mode": "Driving",
"action": "Take Hudson St and I-78 W to NJ-139 W in Jersey City",
"formatted_duration": "15 min",
"formatted_distance": "3.6 mi",
"duration": 882,
"distance": 5774,
"details": [
{
"travel_mode": "Driving",
"action": "Head southeast toward Park Row",
"information": "Partial restricted usage road",
"formatted_duration": "21 sec",
"formatted_distance": "200 ft",
"duration": 21,
"distance": 61,
"latitude": 40.71257449099273,
"longitude": -74.00641981461534
},
...
]
},
...
]
},
{
"travel_mode": "Transit",
"time_window": {
"depart_at": "2:05 PM",
"depart_at_tz": "America/New_York",
"arrive_at": "8:45 AM",
"arrive_at_tz": "America/Chicago"
},
"formatted_duration": "19 hr 40 min",
"formatted_distance": "851 miles",
"duration": 70800,
"distance": 1369556,
"instructions": [
{
"travel_mode": "Transit",
"depart_from": {
"place": "New York (Port Authority Bus Terminal)",
"at": "2:05 PM",
"timezone": "America/New_York",
"latitude": 40.757,
"longitude": -73.99186,
"data_id": "0x89c25852d804d943:0xe56f50849cfe6488"
},
"vehicle": "Bus",
"line_name": "FAB 202",
"line_number": "Pittsburgh",
"formatted_duration": "7 hr 45 min",
"duration": 27900,
"arrive_at": {
"place": "Pittsburgh",
"at": "9:50 PM",
"timezone": "America/New_York",
"latitude": 40.444496,
"longitude": -79.99342,
"data_id": "0x8834f3e26d2e0879:0xb8c52273c7bd107c"
},
"service_provider": {
"name": "Fullington Trailways",
"contact": "1 (800) 942-8287",
"website": "https://ride.fullingtontours.com/"
},
"stops": [
{
"place": "State College (Bus Terminal)",
"at": "7:05 PM",
"timezone": "America/New_York",
"latitude": 40.7921,
"longitude": -77.866,
"data_id": "0x89cea89a2e07410d:0xef633c510c13d93e"
}
]
},
{
"walking": {
"travel_mode": "Walking",
"formatted_duration": "3 min",
"duration": 169
}
},
{
"travel_mode": "Transit",
"depart_from": {
"place": "Pittsburgh Union Station",
"at": "11:59 PM",
"timezone": "America/New_York",
"latitude": 40.444738,
"longitude": -79.992307,
"data_id": "0x8834f1589fe2b1bf:0x6dffce30c7354135"
},
"direction": "Chicago",
"vehicle": "Train",
"line_name": "Floridian",
"line_number": "40",
"formatted_duration": "9 hr 46 min",
"duration": 35160,
"arrive_at": {
"place": "Chicago Union Station",
"at": "8:45 AM",
"timezone": "America/Chicago",
"latitude": 41.8803197,
"longitude": -87.6394109,
"data_id": "0x880e2c8dbbb32f5d:0x5f985dc0044b1109"
},
"service_provider": {
"name": "Amtrak",
"website": "https://www.amtrak.com/"
},
"stops": [
{
"place": "Alliance Amtrak",
"at": "1:39 AM",
"timezone": "America/New_York",
"latitude": 40.921275,
"longitude": -81.09290399999999,
"data_id": "0x8836b4b8cb64b793:0xb13235a1669f926"
},
...
]
}
]
},
{
"travel_mode": "Flying",
"departure": "Newark, NJ",
"arrival": "Chicago, IL",
"formatted_duration": "2 hr 20 min",
"duration": 8400,
"formatted_price": "$145",
"price": 145,
"airlines": [
"Spirit",
"Frontier",
"American"
],
"flights_link": "https://www.google.com/travel/flights?tfs=CAcQAhopEgoyMDI1LTA5LTI4ag0IAhIJL20vMDJfMjg2cgwIAhIIL20vMDFfZDQaKRIKMjAyNS0xMC0wMmoMCAISCC9tLzAxX2Q0cg0IAhIJL20vMDJfMjg2&source=maps&hl=en&authuser=0"
}
]
}
Driving

https://www.searchapi.io/api/v1/search?engine=google_maps_directions&from=Chicago&to=Santa+Monica&travel_mode=driving
- Python
- Node
- Ruby
- Java
- Go
- PHP
- Bash
- R
- Kotlin
- Swift
- C#
- C
- C++
- requests
import requests
url = "https://www.searchapi.io/api/v1/search"
params = {
"engine": "google_maps_directions",
"from": "Chicago",
"to": "Santa Monica",
"travel_mode": "driving"
}
response = requests.get(url, params=params)
print(response.text)
{
"directions": [
{
"travel_mode": "Driving",
"via": "I-80 W",
"formatted_duration": "29 hr",
"duration": 105862,
"distance": 3269280,
"formatted_typical_duration": "29–35 hr",
"optimistic_duration": 103460,
"pessimistic_duration": 126069,
"formatted_distance": "2,031 miles",
"warnings": [
"This route has tolls.",
"Your destination is in a different time zone.",
"Fastest route, the usual traffic"
],
"instructions": [
{
"travel_mode": "Driving",
"action": "Take N Clark St to IL-110 W/Chicago - Kansas City Expy/Dwight D. Eisenhower Expy/Eisenhower Expy",
"formatted_duration": "5 min",
"formatted_distance": "0.8 mi",
"duration": 292,
"distance": 1250,
"details": [
{
"travel_mode": "Driving",
"action": "Head east on W Washington St toward N Clark St",
"formatted_duration": "26 sec",
"formatted_distance": "394 ft",
"duration": 26,
"distance": 120,
"street_view": "https://streetviewpixels-pa.googleapis.com/v1/thumbnail?panoid=avTFVBIVsF3UUWArxWP20A&cb_client=maps_sv.tactile.gps&w=203&h=100&yaw=272.88528&pitch=0&thumbfov=100",
"latitude": 41.8832316,
"longitude": -87.63260404027585
},
...
]
},
...
]
}
]
}
Transit

https://www.searchapi.io/api/v1/search?engine=google_maps_directions&from=New+York&to=Boston&travel_mode=transit
- Python
- Node
- Ruby
- Java
- Go
- PHP
- Bash
- R
- Kotlin
- Swift
- C#
- C
- C++
- requests
import requests
url = "https://www.searchapi.io/api/v1/search"
params = {
"engine": "google_maps_directions",
"from": "New York",
"to": "Boston",
"travel_mode": "transit"
}
response = requests.get(url, params=params)
print(response.text)
{
"directions": [
{
"travel_mode": "Transit",
"time_window": {
"depart_at": "9:30 AM",
"depart_at_tz": "America/New_York",
"arrive_at": "1:50 PM",
"arrive_at_tz": "America/New_York"
},
"buy_ticket": {
"title": "One-way price for 1 adult · Tue, Oct 21",
"price": "$49.99",
"offers": [
{
"source": "Wanderu",
"price": "$49.99",
"link": "https://google-partner.wanderu.com/link?service_date%3D%255B%252220251021%2522%255D%26from_ticketing_stop_time_id%3D%255B%2522NYCUSPPL%2522%255D%26to_ticketing_stop_time_id%3D%255B%2522BOSSSB%2522%255D%26boarding_time%3D%255B%25222025-10-21T13:30:00%252B00:00%2522%255D%26arrival_time%3D%255B%25222025-10-21T17:50:00%252B00:00%2522%255D",
"favicon": "..."
}
]
},
"formatted_duration": "4 hr 20 min",
"formatted_distance": "230 miles",
"duration": 15600,
"distance": 369967,
"instructions": [
{
"travel_mode": "Transit",
"depart_from": {
"place": "Port Authority Bus Terminal",
"at": "9:30 AM",
"timezone": "America/New_York",
"latitude": 40.7569006,
"longitude": -73.9902798,
"data_id": "0x89c258533c0d4f09:0xa8790f841589c36e"
},
"direction": "Boston (South Station), MA",
"vehicle": "Bus",
"line_name": "Peter Pan",
"line_number": "5619",
"formatted_duration": "4 hr 20 min",
"duration": 15600,
"arrive_at": {
"place": "South Station",
"at": "1:50 PM",
"timezone": "America/New_York",
"latitude": 42.3518283,
"longitude": -71.0562097,
"data_id": "0x89e37a78aa90726b:0xa5147c622a35c46a"
},
"service_provider": {
"name": "Peter Pan Bus Lines",
"contact": "1 (800) 343-9999",
"website": "https://peterpanbus.com/"
},
"stops": [
{
"place": "Union Station, Hartford, CT",
"at": "11:50 AM",
"timezone": "America/New_York",
"latitude": 41.768891,
"longitude": -72.681611,
"data_id": "0x89e653614a7366b1:0x520d228b099e1116"
}
]
}
]
},
...
]
}
Walking

https://www.searchapi.io/api/v1/search?engine=google_maps_directions&from=Duke+Ellington+Circle%2C+NYC&to=Columbus+Cir%2C+NYC&travel_mode=walking
- Python
- Node
- Ruby
- Java
- Go
- PHP
- Bash
- R
- Kotlin
- Swift
- C#
- C
- C++
- requests
import requests
url = "https://www.searchapi.io/api/v1/search"
params = {
"engine": "google_maps_directions",
"from": "Duke Ellington Circle, NYC",
"to": "Columbus Cir, NYC",
"travel_mode": "walking"
}
response = requests.get(url, params=params)
print(response.text)
{
"directions": [
{
"travel_mode": "Walking",
"via": "5th Ave",
"formatted_duration": "1 hr 5 min",
"duration": 3893,
"distance": 4686,
"formatted_distance": "2.9 miles",
"instructions": [
{
"travel_mode": "Walking",
"formatted_duration": "1 hr 5 min",
"formatted_distance": "2.9 mi",
"duration": 3893,
"distance": 4686,
"details": [
{
"travel_mode": "Walking",
"action": "Head southwest on 5th Ave toward Duke Ellington Circle",
"information": "Parts of this road may be closed at certain times or days",
"formatted_duration": "36 min",
"formatted_distance": "1.6 mi",
"duration": 2163,
"distance": 2558,
"street_view": "https://streetviewpixels-pa.googleapis.com/v1/thumbnail?panoid=8oJOBNcAAJl58zrwTdmV8A&cb_client=maps_sv.tactile.gps&w=203&h=100&yaw=262.59985&pitch=0&thumbfov=100",
"latitude": 40.79729683620528,
"longitude": -73.9490482000821
},
{
"travel_mode": "Walking",
"action": "Slight right",
"formatted_duration": "52 sec",
"formatted_distance": "171 ft",
"duration": 52,
"distance": 52,
"street_view": "https://streetviewpixels-pa.googleapis.com/v1/thumbnail?panoid=uZdzkK2_HxHVDelhFt-w8A&cb_client=maps_sv.tactile.gps&w=203&h=100&yaw=231.58138&pitch=0&thumbfov=100",
"latitude": 40.77705167096609,
"longitude": -73.96380734846424
},
...
]
}
]
}
]
}
Cycling

https://www.searchapi.io/api/v1/search?engine=google_maps_directions&from=The+Hague&to=Amsterdam&travel_mode=cycling
- Python
- Node
- Ruby
- Java
- Go
- PHP
- Bash
- R
- Kotlin
- Swift
- C#
- C
- C++
- requests
import requests
url = "https://www.searchapi.io/api/v1/search"
params = {
"engine": "google_maps_directions",
"from": "The Hague",
"to": "Amsterdam",
"travel_mode": "cycling"
}
response = requests.get(url, params=params)
print(response.text)
{
"directions": [
{
"travel_mode": "Cycling",
"via": "Hoofdweg Oostzijde",
"formatted_duration": "3 hr 26 min",
"duration": 12365,
"distance": 62110,
"formatted_distance": "62.1 km",
"instructions": [
{
"travel_mode": "Cycling",
"formatted_duration": "3 hr 26 min",
"formatted_distance": "62.1 km",
"duration": 12365,
"distance": 62110,
"details": [
{
"travel_mode": "Cycling",
"action": "Head northeast toward Vaillantlaan/S100",
"formatted_duration": "10 sec",
"formatted_distance": "43 m",
"duration": 10,
"distance": 43,
"street_view": "https://streetviewpixels-pa.googleapis.com/v1/thumbnail?panoid=mS-95UezFIP6d7-StaS2zg&cb_client=maps_sv.tactile.gps&w=203&h=100&yaw=51.68569&pitch=0&thumbfov=100",
"latitude": 52.07018746926732,
"longitude": 4.300649582678608
},
{
"travel_mode": "Cycling",
"action": "Exit the roundabout onto Buitenom/S100",
"formatted_duration": "1 min",
"formatted_distance": "220 m",
"duration": 72,
"distance": 219,
"street_view": "https://streetviewpixels-pa.googleapis.com/v1/thumbnail?panoid=UXJxgIpujkTElkoShXLzkw&cb_client=maps_sv.tactile.gps&w=203&h=100&yaw=9.541462&pitch=0&thumbfov=100",
"latitude": 52.07046915544492,
"longitude": 4.30103743330316
},
...
]
}
]
}
]
}
Flying

https://www.searchapi.io/api/v1/search?engine=google_maps_directions&from=JFK%2C+NYC&to=San+Francisco&travel_mode=flying
- Python
- Node
- Ruby
- Java
- Go
- PHP
- Bash
- R
- Kotlin
- Swift
- C#
- C
- C++
- requests
import requests
url = "https://www.searchapi.io/api/v1/search"
params = {
"engine": "google_maps_directions",
"from": "JFK, NYC",
"to": "San Francisco",
"travel_mode": "flying"
}
response = requests.get(url, params=params)
print(response.text)
{
"directions": [
{
"travel_mode": "Flying",
"departure": "New York, NY",
"arrival": "San Francisco, CA",
"formatted_duration": "5 hr 55 min",
"duration": 21300,
"formatted_price": "$170",
"price": 170,
"airlines": [
"Frontier",
"United",
"JetBlue"
],
"flights_link": "https://www.google.com/travel/flights?tfs=CAcQAhopEgoyMDI1LTExLTA2ag0IAhIJL20vMDJfMjg2cgwIAhIIL20vMGQ2bHAaKRIKMjAyNS0xMS0xMGoMCAISCC9tLzBkNmxwcg0IAhIJL20vMDJfMjg2&source=maps&hl=en&authuser=0"
}
]
}