find-cheapest-gas▌
gasbuddy.com/find-cheapest-gas-weju5k · updated May 21, 2026
MDX-style export adds YAML metadata + attribution linking explainx.ai and this canonical listing URL.
Given a US ZIP code (or City, ST text), return the cheapest gas stations nearby on GasBuddy — with station name, brand, address, fuel grade, current price per gallon, reporter, how recently it was reported, and an optional ZIP-centroid distance. Read-only.
| name | find-cheapest-gas |
| title | GasBuddy Find Cheapest Gas |
| description | >- Given a US ZIP code (or City, ST text), return the cheapest gas stations nearby on GasBuddy — with station name, brand, address, fuel grade, current price per gallon, reporter, how recently it was reported, and an optional ZIP-centroid distance. Read-only. |
| website | gasbuddy.com |
| category | automotive |
| tags | - gas-prices - automotive - cloudflare - next-js - read-only - consumer |
| source | 'browserbase: agent-runtime 2026-05-19' |
| updated | '2026-05-19' |
| recommended_method | browser |
| alternative_methods | - method: hybrid rationale: >- Browser navigation to /home?search=<query>&fuel=N renders the full station list server-side, plus an asynchronous POST /graphql StationPrices XHR hydrates current prices for canonical city slugs. The GraphQL POST is structurally cleaner JSON but requires a gbcsrf cookie (bootstrapped from a prior GET) and prior knowledge of the city slug, so it accelerates repeat queries against the same city rather than replacing the browser path. - method: url-param rationale: >- The URL /home?search=<URL-encoded ZIP or City%2C+ST>&fuel=<1|2|3|4> is the single canonical entry — no form submission needed. ZIP-search has a tight proximity radius (0-2 results for dense urban ZIPs); City-search returns up to 20. |
| verified | false |
| proxies | true |
GasBuddy Find Cheapest Gas
Purpose
Given a US ZIP code (or "City, ST" text), return the cheapest gas stations near that location from GasBuddy — including each station's name, brand, full street address, fuel grade searched, current price per gallon (cash or credit), the reporter who submitted that price, how recently it was reported, and an optional straight-line distance from the ZIP centroid. Read-only — never reports a price, never logs in, never books anything.
When to Use
- A consumer-shopping agent needs to surface the 1-20 cheapest stations near a given ZIP for a specific fuel grade (Regular / Midgrade / Premium / Diesel).
- A trip-planning agent needs station-level prices ranked by cost (not by proximity).
- A market-research workflow scanning prices across multiple cities daily —
/home?search=<query>is the single canonical entry point. - Use
restaurants/opentable-check-availabilitystyle branching — multiple distinct outcome shapes are returned (success-N, success-one, no-stations-for-zip, ambiguous-text-search). See Expected Output below.
Workflow
GasBuddy's /home?search=<query>&fuel=<N> page server-renders a ranked list of cheapest stations as GenericStationListItem cards. The list size is search-term-shape dependent (this is the most important gotcha — see Site-Specific Gotchas):
- A ZIP code → tight proximity search → typically 0-2 stations (just the very cheapest in walking distance from the ZIP centroid). Often zero results for dense urban Manhattan / downtown Chicago ZIPs, where the nearest station is outside the radius.
- A "City, ST" text → city-wide search → up to 20 stations server-rendered in one page.
- A canonical city slug page (
/gasprices/<state-slug>/<city-slug>) → up to 10 stations + an asynchronousStationPricesGraphQL hydration for current prices.
The recommended flow is browser-driven because the page is a fully client-rendered Next.js SPA behind Cloudflare; cookieless HTTP fetches return the HTML shell but skip the post-hydration price refresh. Lead with a Browserbase remote session with residential proxies (--proxies); advanced stealth (--verified) is not required during validation.
1. Open a Browserbase session with proxies
SID=$(browse cloud sessions create --keep-alive --proxies | jq -r .id)
export BROWSE_SESSION="$SID"
--verified was tested and is unnecessary — bare --proxies returned 200s on every request across multiple ZIPs. Skipping --verified halves session cost.
2. Search by ZIP first
FUEL=1 # 1=Regular, 2=Midgrade, 3=Premium, 4=Diesel
URL="https://www.gasbuddy.com/home?search=${ZIP}&fuel=${FUEL}"
browse open "$URL" --remote --session "$SID"
browse wait load --session "$SID"
browse wait timeout 4000 --session "$SID" # post-hydration price refresh
Then browse get html body --session "$SID" to retrieve the fully rendered HTML.
3. Parse GenericStationListItem cards
Split the HTML on the regex class="[^"]*GenericStationListItem-module__station[^"]*"\s+id="(\d+)" — each match anchors one station card. Within each card chunk:
| Field | Selector (regex) | Notes |
|---|---|---|
station_id | id="(\d+)" on the card div | Internal GasBuddy ID; used in /station/{id} URL |
brand | <img alt="([^"]+)" class="image__image[^"]*" (first match in chunk) | "Shell", "76", "Costco", "DataFeed"-stations show generic-pump icon with no alt |
name | inside StationDisplay-module__stationNameHeader, <a href="/station/\d+"[^>]*>([^<]+)</a> | Usually equals brand; sometimes a specific franchise name |
address | <div class="StationDisplay-module__address[^"]*">(.*?)</div> with <br> separator | Line 1 = street, Line 2 = "City, ST" |
rating_count | class="[^"]*numberOfReviews[^"]*">(\d+)< | Optional review count |
price | <span class="[^"]*StationDisplayPrice-module__price[^"]*">([^<]+)</span> | Format $X.XX or - - - when stale |
reporter | class="[^"]*ReportedBy-module__memberLink[^"]*"\s+href="(/member/[^"]+)"[^>]*>(?:<img[^>]*>)?(?: )?([^<]+)< | Captures both /member/<username> URL and display name. Special reporter DataFeed (/member/datafeed) = automated price feed, not a real user |
reported_age | <span class="[^"]*ReportedBy-module__postedTime[^"]*">([^<]+)</span> | Free-text relative time: "4 Minutes Ago", "6 Hours Ago", "2 Days Ago". Convert to absolute by subtracting from Date.now() |
payment_badge | <div class="[^"]*StationDisplayPrice-module__[^"]*">.*?(CASH|CREDIT) near price | Cash-discount marker. Absent when not applicable |
fuel_grade | fuel URL param echoed back (1→regular, 2→midgrade, 3→premium, 4→diesel) | Not on the card; carry from the request |
4. Branch on result count
After parsing:
- 2+ stations → emit
outcome: "stations_for_zip"with the parsed list. - 1 station → emit
outcome: "single_cheapest_for_zip"(this is the dominant ZIP-search shape —/home?search=ZIPis a tight-radius query and most ZIPs surface exactly the local cheapest). - 0 stations + visible "No stations found. Try refining your search." → fall through to step 5. Do not emit success-with-zero — the search was too narrow, not actually empty.
The page also renders a <state> Gas Price Stats panel with $X.XX Lowest and $Y.YY Average regardless of station list — extract these as state_lowest_usd and state_average_usd in every response (they're always present and confirm which US state the ZIP geocoded to).
5. Fall back: widen to "City, ST" search
When ZIP-based search returns 0 stations:
- Read the state name from the stats panel header — regex
>(\w[\w ]+?) Gas Price Stats<→ e.g."New York","Illinois". - Resolve ZIP → city. GasBuddy itself does not provide a public ZIP→city lookup on this surface; use either: (a) a local
pyzipcode/uszipcodelibrary, (b) an external geocoding service, or (c) a precomputed table of major-metro ZIPs. The skill caller is expected to provide this — see thecity_hintinput field in the example output schema. - Re-issue
/home?search=<URL-encoded "City, ST">&fuel=Nand re-parse. This returns up to 20 stations.
Alternatively — if all that's available is the state — navigate to the canonical state directory https://www.gasbuddy.com/gasprices/<state-slug> (slug = state name lowercased, spaces → hyphens: "new-hampshire", "washington-dc") and pick a metro from there. The dollar-amount Stats panel on /home?search=ZIP also gives a state-wide lowest/average usable as a coarse fallback signal.
6. (Optional) Compute distance from ZIP centroid
The web UI does not display distance. To populate the distance_mi field:
- After the first navigation, click VIEW MAP (or evaluate the link
href) — it navigates to/gaspricemap?fuel=1&z=13&lat=<LAT>&lng=<LNG>whereLAT/LNGis the geocoded ZIP centroid. Capture those two query params before navigating to the map (it's enough to read the link'shref). - Each station's
latitude/longitudeis inwindow.__APOLLO_STATE__underStation:<id>entries — read viabrowse eval "return window.__APOLLO_STATE__"and locate by station ID. - Compute haversine distance in miles between ZIP and station coordinates.
Distance is post-processed — GasBuddy does not return it in the rendered HTML.
7. Release the session
browse cloud sessions update "$SID" --status REQUEST_RELEASE
Hybrid alternative: direct GraphQL (advanced, fragile)
The page issues POST https://www.gasbuddy.com/graphql with operationName: "StationPrices" and variables { area, countryCode, criteria: { location_type: ["locality","metro"] }, fuel, regionCode } to hydrate prices for a city slug. Headers required: content-type: application/json, apollo-require-preflight: true, gbcsrf: <token> (from a gbcsrf cookie set on first page load). The response carries cash / credit { nickname, postedTime (ISO 8601), price, formattedPrice } per station — structurally cleaner than HTML parsing.
Do not lead with this — it requires (a) bootstrapping a cookie jar from a real GET to set gbcsrf, (b) prior knowledge of the canonical city slug and state code (no ZIP-based variant of this operation has been observed), and (c) the operation set rotates with frontend deploys. The browser path tolerates all of that automatically. The GraphQL POST is documented here as a hybrid accelerator for repeated queries against the same city slug where reducing per-request latency is worth the cookie-management complexity.
Site-Specific Gotchas
- ZIP-based search is a tight-radius proximity query, not a city search.
/home?search=10001&fuel=1(Manhattan) returns the literal "No stations found. Try refining your search." text — 0 stations — because the nearest reported station is outside the radius GasBuddy uses for ZIP queries. The page still renders a "<State> Gas Price Stats" panel, which tricks naïve parsers into thinking the search worked. Verified on10001(Manhattan) and60601(downtown Chicago) — both returned 0 stations despite having dozens of stations within 2 miles. The same query with?search=Chicago%2C+ILreturned 20 stations. - Same surface, two different result-size ceilings.
/home?search=is the only URL pattern that returns up to 20 stations server-rendered in one HTML response; the canonical city page/gasprices/<state>/<city>is capped at 10. If you want a long list, use/home?search=City%2C+ST, not the city page. - No native distance field. GasBuddy's web UI never displays distance from the search point. Distance must be computed client-side from station
latitude/longitude(available inwindow.__APOLLO_STATE__underStation:<id>) and the ZIP centroid (parsable from theVIEW MAPlink'slat=/lng=URL params). Honesty rule: if you can't get both coordinates, emitdistance_mi: nullrather than guessing. DataFeedreporter is an automated price feed, not a person. Stations withreporter: "DataFeed"(linking to/member/datafeed) are price-fed from POS systems or third-party data partners, not crowd-reported by a user. Surface this in the output asreporter_type: "automated"so downstream callers can distinguish freshness sources —DataFeedprices tend to be more recent than crowd reports.- Stale prices render as
- - -, not$0.00or null. Stations with no recent report show<span>- - -</span>in the price slot and have noReportedByblock. Treat asprice: null, reported_age: nullrather than dropping the row — the address + brand are still useful metadata. fuelis a 1-indexed enum, not a fuel-product string. URL paramfuel=1Regular,fuel=2Midgrade,fuel=3Premium,fuel=4Diesel. The GraphQLprices(fuel: N)argument uses the same integer mapping. Omitfuelfrom the URL and GasBuddy defaults to Regular (fuel=1); other absent values are not silently substituted.?maxAge=0is "no max age" (i.e. show all reports including ancient ones), NOT "must be 0 minutes old". This is the inverse of what the URL implies. SetmaxAgeto a positive integer (minutes) only if you want to filter out stale reports. Default is unset (no filter).- The form's
FIND GASbutton is decorative when the URL already has?search=. Abrowse clickon the FIND GAS button just re-canonicalizes the URL params (alphabetizes them) and re-runs the same search — no new state. Don't waste a turn clicking it; the URL param is the single source of truth. /gas-prices/<ST>/<ZIP>(with hyphen) issues a 308 redirect to the lowercase variant/gas-prices/<st>/<zip>, which then 404s. This URL pattern is not a working ZIP-page surface. Don't waste time on it. The working ZIP entry is/home?search=<ZIP>.- Canonical city slug pattern is
/gasprices/<state-slug>/<city-slug>(no hyphen ingasprices). Cousin pattern/gas-prices/<state>/<city>(with hyphen) 404s. Slug rules: lowercase, spaces → hyphens, no diacritics.washington-dc,new-hampshire,puerto-rico,beverly-hills. - The
/gaspricemappage is a heatmap, not a station list. ClickingVIEW MAPfrom a search result navigates to/gaspricemap?fuel=N&z=13&lat=X&lng=Ywhich renders an interactive Mapbox-style heatmap with no per-station list in the DOM. Useful only to extract the ZIP centroid(lat, lng)from the URL — not for harvesting stations. - Cloudflare protects the site, but residential proxies alone are sufficient.
browse cloud sessions create --keep-alive --proxieswas tested across 4 distinct ZIPs (90210, 10001, 60601, 75201) and got200 OKon every page load.--verifiedwas not required. If a future run gets blocked, add--verifiedas the first escalation. - Apollo state (
window.__APOLLO_STATE__) is server-rendered with addresses + lat/lon but NOT prices. Don't expect to grab prices straight from the Apollo blob — they arrive in a laterStationPricesGraphQL POST. The rendered HTML afterwait timeout 4000is the only reliable source of fresh price + reporter + age data. - GraphQL POST requires
gbcsrfheader from cookie. A barecurltohttps://www.gasbuddy.com/graphqlreturns400 Bad requestwith no payload. Thegbcsrftoken is set as a same-site cookie by the first GET to anygasbuddy.compage. Browser path picks this up for free; direct API path requires bootstrapping a cookie jar first. - Cookie banner overlays the bottom 60-90px of every page. Doesn't block extraction (the underlying DOM is rendered) but truncates screenshots. Clicking "Reject All" before screenshotting is optional; the data extraction works regardless.
Expected Output
Four distinct outcome shapes — emit exactly one per call.
// Outcome 1: ZIP search returned 2+ stations
{
"outcome": "stations_for_zip",
"zip": "75201",
"fuel_grade": "regular",
"state": "Texas",
"state_lowest_usd": 2.74,
"state_average_usd": 3.05,
"zip_centroid": { "lat": 32.7872, "lng": -96.79925 },
"stations": [
{
"station_id": "44331",
"name": "Texaco",
"brand": "Texaco",
"address_line1": "2607 San Jacinto St",
"address_city_state": "Dallas, TX",
"latitude": 32.7842,
"longitude": -96.7975,
"fuel_grade": "regular",
"price_usd": 4.19,
"price_display": "$4.19",
"payment_badge": null,
"reporter": "DataFeed",
"reporter_url": "https://www.gasbuddy.com/member/datafeed",
"reporter_type": "automated",
"reported_age": "6 Hours Ago",
"distance_mi": 0.18,
"station_url": "https://www.gasbuddy.com/station/44331"
}
]
}
// Outcome 2: ZIP search returned exactly 1 station (most common for residential/non-dense ZIPs)
{
"outcome": "single_cheapest_for_zip",
"zip": "90210",
"fuel_grade": "regular",
"state": "California",
"state_lowest_usd": 4.49,
"state_average_usd": 6.14,
"zip_centroid": { "lat": 34.10106, "lng": -118.41473 },
"stations": [ { /* same shape as above, exactly one entry */ } ]
}
// Outcome 3: ZIP search returned 0 stations (dense urban / radius-exceeded)
{
"outcome": "no_stations_for_zip",
"zip": "10001",
"fuel_grade": "regular",
"state": "New York",
"state_lowest_usd": 3.99,
"state_average_usd": 4.58,
"zip_centroid": { "lat": 40.7506, "lng": -73.99723 },
"stations": [],
"fallback_suggestion": "retry with `search=<City>%2C+<ST>` where City/ST is derived from a ZIP→city lookup (skill input field `city_hint`); /home?search=New+York%2C+NY returned 20 stations on validation."
}
// Outcome 4: caller passed a "City, ST" string (or ZIP fallback widened to city) — returns up to 20
{
"outcome": "stations_for_city",
"query": "Chicago, IL",
"fuel_grade": "regular",
"state": "Illinois",
"state_lowest_usd": 4.20,
"state_average_usd": 5.05,
"stations": [ /* up to 20 station entries; ordered cheapest-first */ ]
}
Field rules:
fuel_gradevalues:"regular","midgrade","premium","diesel"— derived from thefuelURL param (1→4).price_usdis the numeric value;price_displaypreserves the rendered string ("$4.19"or"- - -").reporter_typeis"automated"whenreporter == "DataFeed", else"crowd".reported_agepreserves the human string verbatim. Callers who want absolute timestamps should subtract fromDate.now()at parse time.distance_miisnullunless step 6 of the workflow was executed (lat/lon-based haversine from ZIP centroid).latitude/longitudeper station are only populated ifwindow.__APOLLO_STATE__was harvested (browse eval); they arenullif only the HTML was scraped.
How to use find-cheapest-gas on Cursor
AI-first code editor with Composer
Prerequisites
Before installing skills in Cursor, ensure your development environment meets these requirements:
- ›Cursor installed and configured on your development machine
- ›Node.js version 16.0+ with npm package manager (verify with
node --version) - ›Active project directory or workspace where you want to add find-cheapest-gas
Execute installation command
Execute the skills CLI command in your project's root directory to begin installation:
The skills CLI fetches find-cheapest-gas from GitHub repository gasbuddy.com/find-cheapest-gas-weju5k and configures it for Cursor.
Select Cursor when prompted
The CLI will show a list of available agents. Use arrow keys to navigate and space to select Cursor:
Verify installation
Confirm successful installation by checking the skill directory location:
Reload or restart Cursor to activate find-cheapest-gas. Access the skill through slash commands (e.g., /find-cheapest-gas) or your agent's skill management interface.
Security & Verification Notice
We perform automated surface-level scans (Gen AI Scanner, Socket, Snyk) during installation. These checks detect common vulnerabilities but do not guarantee complete security. Always review skill source code and verify the publisher's reputation before production use.
Skills execute code in your development environment. Always verify the publisher's identity, review recent commits, and test in isolated environments before production deployment.
List & Monetize Your Skill
Submit your Claude Code skill and start earning
Use Cases▌
Task Automation & Efficiency
Automate repetitive workflows and reduce manual effort
Example
Generate reports, summarize documents, draft communications
Save 3-5 hours per week on routine tasks
Knowledge Enhancement
Learn new skills, understand complex topics, get expert guidance
Example
Explain concepts, provide examples, suggest learning resources
Accelerate learning and skill development by 2x
Quality Improvement
Enhance output quality through reviews, suggestions, and refinements
Example
Review drafts, suggest improvements, catch errors
Improve work quality by 30-40% with less effort
Implementation Guide▌
Prerequisites
- ›Claude Desktop or compatible AI client with skill support
- ›Clear understanding of task or problem to solve
- ›Willingness to iterate and refine outputs
Time Estimate
15-45 minutes depending on use case complexity
Installation Steps
- 1.Install skill using provided installation command
- 2.Test with simple use case relevant to your work
- 3.Evaluate output quality and relevance
- 4.Iterate on prompts to improve results
- 5.Integrate into regular workflow if valuable
Common Pitfalls
- ⚠Expecting perfect results without iteration
- ⚠Not providing enough context in prompts
- ⚠Using skill for tasks outside its intended scope
- ⚠Accepting outputs without review and validation
Best Practices▌
✓ Do
- +Start with clear, specific prompts
- +Provide relevant context and constraints
- +Review and refine all outputs before using
- +Iterate to improve output quality
- +Document successful prompt patterns
✗ Don't
- −Don't use without understanding skill limitations
- −Don't skip validation of outputs
- −Don't share sensitive information in prompts
- −Don't expect skill to replace human judgment
💡 Pro Tips
- ★Be specific about desired format and style
- ★Ask for multiple options to choose from
- ★Request explanations to understand reasoning
- ★Combine AI efficiency with human expertise
When to Use This▌
✓ Use When
Use when skill capabilities match your task, clear ROI on time saved, and you can validate outputs. Best for repetitive tasks, learning, and quality improvement.
✗ Avoid When
Avoid when task requires deep expertise you can't validate, involves sensitive decisions, or when learning process is more valuable than speed of completion.
Learning Path▌
- 1Familiarize yourself with skill capabilities and limitations
- 2Start with low-risk, non-critical tasks
- 3Progress to more complex and valuable use cases
- 4Build expertise through regular use and experimentation
Discussion
Product Hunt–style comments (not star reviews)- No comments yet — start the thread.
Ratings
4.6★★★★★54 reviews- ★★★★★Carlos Brown· Dec 20, 2024
find-cheapest-gas fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.
- ★★★★★Mei Haddad· Dec 16, 2024
find-cheapest-gas is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.
- ★★★★★Alexander Anderson· Dec 4, 2024
find-cheapest-gas reduced setup friction for our internal harness; good balance of opinion and flexibility.
- ★★★★★Ira Jain· Dec 4, 2024
find-cheapest-gas has been reliable in day-to-day use. Documentation quality is above average for community skills.
- ★★★★★Rahul Santra· Nov 23, 2024
Useful defaults in find-cheapest-gas — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.
- ★★★★★Valentina Nasser· Nov 23, 2024
find-cheapest-gas has been reliable in day-to-day use. Documentation quality is above average for community skills.
- ★★★★★Valentina Haddad· Nov 23, 2024
find-cheapest-gas reduced setup friction for our internal harness; good balance of opinion and flexibility.
- ★★★★★Sakura Li· Nov 11, 2024
We added find-cheapest-gas from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.
- ★★★★★Kaira Malhotra· Nov 7, 2024
Keeps context tight: find-cheapest-gas is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Li White· Oct 26, 2024
I recommend find-cheapest-gas for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.
showing 1-10 of 54