✈️ Google Flights Scraper
Pricing
from $5.00 / 1,000 flight itinerary records
✈️ Google Flights Scraper
Find the cheapest flights for any route in one API call. Returns 5 best fares + 25-50 alternates: airline, price, times, stops, layovers, bookable links. For travel agencies, AI flight agents, and price-tracking products. Export, run via API, schedule, or integrate with other tools.
Pricing
from $5.00 / 1,000 flight itinerary records
Rating
0.0
(0)
Developer
Skootle
Maintained by CommunityActor stats
0
Bookmarked
2
Total users
1
Monthly active users
a day ago
Last modified
Categories
Share

TL;DR
Pull every flight Google returns for any route and date pair in one API call. Returns the 5 best fares plus 25-50 alternates per query: airline, price, departure / arrival times, stops, layover detail, and a bookable link per itinerary. Built for travel-agency price desks, AI flight-finding agents, price-tracking products like Hopper or Going, corporate T&E tools, and affiliate publishers running daily fare sweeps. One LAX→JFK round-trip search costs about $0.21 on the GOLD plan.
Try it on a single route, then let us know what you think in a review.
What does Google Flights Scraper do?
Today, the manual workflow is brutal. A travel-agency price-ops analyst opens google.com/travel/flights, types in LAX→JFK on June 15, copies the cheapest 5 fares into a spreadsheet, changes the date to June 16, copies again, and repeats 30 times to fill out a price calendar for one client trip. A price-tracking startup like Going hires people to do that across thousands of routes a day. An AI travel agent that can't get structured fare data has to screen-scrape Google itself and break every two weeks.
This actor collapses that workflow into a single API call per route and date pair. Send the route, dates, cabin class, and passenger mix; get back every itinerary Google returns with airlines, prices, times, stops, layovers, and a bookable link per fare.
Per query you also get one price_insights summary row with median, P10, P90, and price range across the itinerary set, so you can answer "is $210 LAX→JFK cheap?" in the same response.
For AI agents and LLM pipelines, every itinerary record carries an agentMarkdown field: a 4-bullet markdown card with airline, duration, price, and bookable link, ready to paste straight into a Claude or ChatGPT context with no formatting work. Records also carry a stable itineraryId so the same flight across multiple runs upserts cleanly.
Why scrape Google Flights?
Google Flights changes prices every few minutes and aggregates fares from every major airline plus most OTAs. Buyers book at the prices Google shows. But Google doesn't expose a 30-day price grid for any route, so travel agencies, AI flight agents, price-tracking apps, and corporate T&E tools all rebuild it manually: open the page, type the route, change the date, copy the cheapest fare, repeat 30 times for one client trip.
Live fare data turns into client invoices, push-notification revenue, "you could have saved $400" upsells, and bookable answers in chat. SerpAPI charges ~$50 per 1,000 searches and skips booking links. Skyscanner's partner API is gated behind an application most teams never get into. Free actors return null-heavy junk: missing cabin class, empty layovers, ignored dates. This one collapses 30 manual searches into one API call with the bookable link attached.
Who needs this?
- Travel agency price-ops analysts running nightly fare sweeps for client routes and emailing the cheapest options before the agent's morning standup
- Price-tracking products (Hopper, Going, Scott's Cheap Flights clones) ingesting daily fare snapshots across thousands of routes to power deal alerts
- AI flight-finding agents built on Claude, ChatGPT, n8n, or LangChain that need a real bookable answer, not a screenshot of Google
- Corporate travel and T&E SaaS (Navan, TripActions style) showing "you could have booked the same trip for $X" in the post-trip report
- OTA and metasearch startups building MVPs that need a live fare backbone before signing partnership deals with airlines
- Affiliate publishers running SEO content like "cheapest flights LAX→JFK in October" that needs fresh price data daily
- Data and analytics teams building route-level price-history datasets for forecasting, hedging, or M&A diligence
How to use Google Flights Scraper
- Open the Input tab on the actor page
- Set
originanddestinationas 3-letter IATA codes (LAX,JFK,LHR,NRT) - Set
departureDateinYYYY-MM-DDformat - Optionally set
returnDate(omit for one-way),passengers,cabinClass, andstops - Set
maxItems(default 50; raise for production runs that need every alternate Google returns) - Click Start or call the actor via the Apify REST API or CLI
You can run on demand from the Console, schedule daily fare sweeps with Apify's cron scheduler, integrate with Make, Zapier, n8n, Slack, or Google Sheets, or pipe directly into a Claude or ChatGPT custom agent.
How much will scraping Google Flights cost?
This actor is priced per event. Two events:
- Actor Start: $0.005 once per run
- Itinerary record: tiered, charged per record written (each
flight_itineraryandprice_insightsrow counts)
| Apify plan | $/1000 records |
|---|---|
| FREE | $12.00 |
| BRONZE | $10.00 |
| SILVER | $9.00 |
| GOLD | $8.00 |
| PLATINUM | $8.00 |
| DIAMOND | $8.00 |
A typical LAX→JFK round-trip query returns 25-50 itineraries plus 1 price_insights row. On the GOLD plan that costs roughly $0.21 per search. A daily price-tracking run across 100 routes runs about $21 per day on GOLD or $14 per day on PLATINUM / DIAMOND. The $5/month Apify free credit covers around 400 trial searches on the FREE plan.
You only pay for records actually saved. If a route returns no results, you don't pay for the empty.
Is it legal to scrape Google Flights?
Yes for personal travel planning, internal price monitoring, agent workflows, and downstream analytics. The actor reads the same publicly rendered fare data that any web browser sees on google.com/travel/flights. It does not authenticate, does not bypass any technical access control, does not access logged-in or paid-tier data, and does not store personal Google account information.
For commercial redistribution (reselling raw fare grids as a competing meta-search product), Google's terms of service apply. Consult your own legal counsel.
Examples
Example 1: One-way LAX→JFK on June 15, agency client trip
{"origin": "LAX","destination": "JFK","departureDate": "2026-06-15","passengers": { "adults": 1 },"maxItems": 25}
Example 2: Family of four, business class, SFO→LHR round-trip
{"origin": "SFO","destination": "LHR","departureDate": "2026-07-10","returnDate": "2026-07-24","passengers": { "adults": 2, "children": 2 },"cabinClass": "BUSINESS","stops": "NONSTOP","maxItems": 50}
Example 3: Daily price-tracking sweep, ATL→MIA round-trip
{"origin": "ATL","destination": "MIA","departureDate": "2026-08-01","returnDate": "2026-08-08","maxItems": 100}
Schedule daily; diff the priceUsd field across runs to catch price drops and trigger deal alerts.
Example 4: Corporate T&E, cheapest BOS→SFO option in week of June 1
{"origin": "BOS","destination": "SFO","departureDate": "2026-06-01","stops": "ONE_STOP_OR_FEWER","cabinClass": "ECONOMY","maxItems": 25}
Drop the cheapest result into the post-trip "you could have saved" report.
Example 5: AI agent answering "cheapest flight Friday to Vegas"
{"origin": "ORD","destination": "LAS","departureDate": "2026-05-15","passengers": { "adults": 1 },"maxItems": 10}
Pipe the top 3 results plus the agentMarkdown cards back into the chat reply.
Example 6: Affiliate SEO content, premium economy LHR→JFK
{"origin": "LHR","destination": "JFK","departureDate": "2026-09-15","returnDate": "2026-09-22","cabinClass": "PREMIUM_ECONOMY","maxItems": 50}
Example 7: Award-fare research baseline, JFK→NRT business class
{"origin": "JFK","destination": "NRT","departureDate": "2026-11-10","returnDate": "2026-11-22","cabinClass": "BUSINESS","stops": "ANY","maxItems": 50}
Input parameters
| Field | Type | Default | Description |
|---|---|---|---|
origin | string (IATA) | required | 3-letter origin airport |
destination | string (IATA) | required | 3-letter destination airport |
departureDate | YYYY-MM-DD | required | Outbound date |
returnDate | YYYY-MM-DD | null | Omit for one-way |
passengers | object | {adults:1} | adults + children + infants |
cabinClass | enum | ECONOMY | ECONOMY, PREMIUM_ECONOMY, BUSINESS, FIRST |
stops | enum | ANY | ANY, NONSTOP, ONE_STOP_OR_FEWER |
currency | string | USD | ISO 4217 |
fareCalendar30d | bool | false | Reserved for v0.2 (30-day fan-out) |
resolveBookingUrls | bool | true | v0.1: opaque token always returned; resolved deeplink lands in v0.2 |
maxItems | int | 50 | Hard cap on itinerary records |
proxyConfiguration | object | residential US | Apify proxy override |
Google Flights output format
The dataset has two record types. Filter by recordType.
flight_itinerary
| Field | Type | Description |
|---|---|---|
outputSchemaVersion | string | Date-stamped schema version ('2026-05-09'), pin downstream pipelines safely |
recordType | literal | 'flight_itinerary' |
itineraryId | string | Stable ID for the itinerary; same flight across runs has same ID, drop into INSERT ... ON CONFLICT DO UPDATE |
origin, destination | object | { iata, name, city } for both ends |
departureDate, returnDate | string / null | ISO date for outbound and return (return is null on one-way) |
priceUsd, priceCurrency | number / string | Numeric fare in your chosen currency |
priceTier | enum | BEST (Google's top picks) or OTHER (alternates), filter for BEST to surface only the recommended fares |
legs[] | array | One per flight segment: flightNumber, airline {iata, name, logoUrl}, departure/arrival airports, ISO times, durationMinutes, aircraft, legroomInches, oftenDelayed, bookableSeats |
totalDurationMinutes, stops, layovers[] | number / array | Layover detail with airport, duration, overnight flag |
baggage | object | { carryOnIncluded, checkedIncluded, selfTransferRequired }, typed booleans, not free-text marketing strings |
carbonGramsCo2, carbonVsRouteAvgPercent | number / null | Sustainability fields for buyers who need them; ignore otherwise |
bookingToken, bookingUrlResolved, bookingProvider | string / null | Token always present in v0.1; resolved deeplink to Expedia / airline direct lands in v0.2 |
agentMarkdown | string | 4-bullet markdown card (✈️ airline, 💰 price, ⏱️ duration, 🔗 booking), paste into Claude / ChatGPT / Slack as-is |
fieldCompletenessScore | int 0-100 | Self-filtering signal so downstream pipelines can drop sparse rows |
scrapedAt | string | ISO 8601 |
price_insights
One row per query, summarizing the itinerary set. Use it to answer "is this fare cheap or expensive vs what Google returned today?":
| Field | Type | Description |
|---|---|---|
query | object | { origin, destination, departureDate, returnDate } echo of your input |
comps | object / null | { n, medianUsd, p10Usd, p90Usd, rangeLowUsd, rangeHighUsd, typicalRange }, n is sample size |
Output example (itinerary)
{"recordType": "flight_itinerary","outputSchemaVersion": "2026-05-09","itineraryId": "a1b2c3d4e5f60718","origin": { "iata": "LAX", "name": "Los Angeles International", "city": "Los Angeles" },"destination": { "iata": "JFK", "name": "John F. Kennedy International", "city": "New York" },"departureDate": "2026-06-15","returnDate": null,"priceUsd": 219,"priceCurrency": "USD","priceTier": "BEST","legs": [{"flightNumber": "B6824","airline": { "iata": "B6", "name": "JetBlue", "logoUrl": null },"departureAirport": "LAX","arrivalAirport": "JFK","departureTimeIso": "2026-06-15T22:25:00.000Z","arrivalTimeIso": "2026-06-16T07:00:00.000Z","durationMinutes": 335,"aircraft": null,"legroomInches": null,"oftenDelayed": false,"bookableSeats": null}],"totalDurationMinutes": 335,"stops": 0,"layovers": [],"baggage": { "carryOnIncluded": null, "checkedIncluded": null, "selfTransferRequired": false },"carbonGramsCo2": 250000,"carbonVsRouteAvgPercent": -8,"bookingToken": "Cj...long...base64...","bookingUrlResolved": null,"bookingProvider": null,"agentMarkdown": "✈️ JetBlue B6824 · LAX→JFK\n💰 $219 (BEST)\n⏱️ 5h 35m nonstop\n🔗 bookingToken ready to resolve","fieldCompletenessScore": 80,"scrapedAt": "2026-05-09T17:00:00.000Z"}
During the Actor run
A typical single-route query returns 10-50 itineraries in 6-10 seconds over Apify residential proxy. No login, no API key, no Google account required.
The actor writes three things to the key-value store at run end:
OUTPUT, compact run summary: query, itinerary count, error counts, finished timestampAGENT_BRIEFING, markdown digest with the top 10 cheapest itineraries ranked by completeness, ready to paste into an LLM context- The default dataset, exportable as CSV / JSON / JSONL / Excel
FAQ
How is this different from SerpAPI's google_flights?
SerpAPI's google_flights is the gold-standard third-party API, and it costs roughly $50 per 1,000 searches with no resolved booking links. This actor lands at $8-12 per 1,000 records on tiered pricing, mirrors SerpAPI's best_flights / other_flights / price_insights shape so you can swap providers later, and ships agent-grade fields (agentMarkdown, fieldCompletenessScore, stable itineraryId hash) SerpAPI does not.
How is this different from johnvc's Google Flights actor?
johnvc's actor is the volume leader and a solid baseline. We differ on three axes: (1) we ship structured baggage as typed booleans instead of free-text "extensions", (2) we return ISO 8601 times with timezone instead of "2026-06-15 23:25" strings, (3) every itinerary carries a stable itineraryId SHA hash so cross-run dedupe works without writing custom keys. johnvc returns the raw booking_token; we'll resolve to a deeplink in v0.2.
Will this break when Google changes their UI?
You're insulated. Hand-tuned for this source, fixes ship the same week the source changes, typically within 24-48 hours. Issues are tracked on the actor page and resolved fast, and the daily auto-test catches regressions before you do.
Will the daily auto-test stay green?
Yes. The default maxItems: 50 plus a typical 6-10 second runtime per query keeps the auto-test under the Apify 5-minute window with margin. We monitor the auto-test status daily.
Why do I sometimes get 0 itineraries?
Google occasionally rotates internal response shapes. The parser is defensive: it returns 0 itineraries instead of throwing on shape drift, so your pipeline gets a clean empty record instead of a crashed run. Open an issue with your input and we'll patch within 48 hours.
Why is bookingUrlResolved null in v0.1?
The two-hop deeplink resolver requires an additional follow-up call against a different Google endpoint that wasn't ready for v0.1. The raw bookingToken is always returned and you can resolve it yourself today; v0.2 will populate bookingUrlResolved and bookingProvider server-side.
Can I monitor only price drops since the last run?
Use the itineraryId as your dedupe key on the consumer side: re-running the same query produces the same itineraryId per itinerary, so a downstream sink can INSERT ... ON CONFLICT DO UPDATE on the price field and trigger an alert when it drops. A built-in watchlist mode is on the roadmap for v0.2.
Can I integrate with Make / Zapier / n8n / Slack?
Yes. Apify provides native integrations for all of those. From the actor page, click Integrations and pick your destination.
Can I use this with Python?
Yes. Use the Apify Python client: client.actor("skootle/google-flights-scraper").call(run_input={...}) and read the dataset.
What's the cheapest way to use this?
The $5/month Apify free credit covers around 400 itinerary records on the FREE plan, enough to validate the schema against your pipeline. For production volume, the GOLD plan at $8 per 1,000 records is the sweet spot; PLATINUM and DIAMOND match GOLD on this actor.
Why does this cost more than the free Google Flights actors?
The free actors return null-heavy or shallow output: dates ignored, layovers empty, baggage missing, no stable IDs. If you're feeding this into a customer-facing product or a daily AI-agent run, the per-record cost buys you reliability the free actors can't deliver, they break monthly when Google's response shape changes, you don't get notified, and your downstream pipeline silently goes empty.
Your feedback
Hit a bug or want a feature? Open an issue on the Issues tab rather than the reviews page, and we'll fix it fast (typically within 48 hours).
Why choose Google Flights Scraper
- One API call replaces 30 manual searches, every fare Google returns for your route and dates in 6-10 seconds
- Bookable links per itinerary, every result ships with the token (and v0.2 resolves to Expedia or airline direct)
- 5 BEST + 25-50 alternates per query, Google's own top picks plus the long tail
- Price comps in the same response, the
price_insightsrow tells you if today's cheapest is below median, P10, or P90 - Watchlist-friendly for price drops, stable IDs make daily-diff price-drop alerts trivial on the consumer side
- SerpAPI-shape parity at a fraction of the cost, ~$8 per 1,000 records vs SerpAPI's ~$50
- AI agents can self-filter sparse rows and paste
agentMarkdowncards straight into Claude or ChatGPT - Safe to dedupe across re-runs, stable
itineraryIdupserts cleanly - Schema doesn't break your pipeline, versioned and date-stamped on every record
Other Skootle actors you might want to check
- Reddit Subreddit Monitor, same agent-grade record schema, applied to Reddit posts and comments. Useful for travel-deal subreddit monitoring.
- Hacker News Watchlist, daily HN top/new/best/ask/show stream with idempotent IDs and
agentMarkdownfor AI agent pipelines. - SEC EDGAR Filings Monitor, public-company filings stream for travel-industry analysts (Booking, Expedia, Airbnb, Marriott).
Export, run via API, schedule, or integrate with other tools.
Support and contact
File issues on this actor's page (Issues tab), replies within 48 hours. For feature requests, drop them in the same tracker tagged enhancement.