Skip to main content
AI/MLjeremylongshore

serpapi-common-errors

'Diagnose and fix SerpApi errors: invalid keys, exhausted credits, blocked

Stars
2,267
Source
jeremylongshore/claude-code-plugins-plus-skills
Updated
2026-05-31
Slug
jeremylongshore--claude-code-plugins-plus-skills--serpapi-common-errors
View on GitHubRaw SKILL.md

// install — copy + paste into any project

mkdir -p .claude/skills && curl -fsSL https://raw.githubusercontent.com/jeremylongshore/claude-code-plugins-plus-skills/HEAD/plugins/saas-packs/serpapi-pack/skills/serpapi-common-errors/SKILL.md -o .claude/skills/serpapi-common-errors.md

Drops the SKILL.md into .claude/skills/serpapi-common-errors.md. Works with Claude Code, Cursor, and any agent that loads SKILL.md files from .claude/skills/.

SerpApi Common Errors

Overview

Quick reference for SerpApi errors. Check search_metadata.status first -- it will be Success or Error. Error details are in search_metadata.error or error at the top level.

Error Reference

Invalid API Key

{ "error": "Invalid API key. Your API key should be here: https://serpapi.com/manage-api-key" }

Fix: Verify key at serpapi.com/manage-api-key. Check env var is loaded.

Account Disabled / Searches Exhausted

{ "error": "Your searches for the month have run out. You can upgrade your plan at https://serpapi.com/pricing" }

Fix: Check usage: curl "https://serpapi.com/account.json?api_key=$SERPAPI_API_KEY". Upgrade plan or wait for monthly reset.

Missing Required Parameter

{ "error": "Missing parameter: q. Please provide a search query." }

Fix: Each engine has different query params. Google/Bing use q, YouTube uses search_query.

Google CAPTCHA / Blocked

{ "search_metadata": { "status": "Error" }, "error": "Google hasn't returned any results for this query." }

Fix: SerpApi handles CAPTCHAs automatically, but unusual queries or very high volume may trigger blocks. Try different location or wait.

Empty Organic Results (Not an Error)

result = client.search(engine="google", q="xyzzy123nonexistent")
if not result.get("organic_results"):
    # Not an error -- query just has no results
    # Check for answer_box, knowledge_graph, etc.
    print("No organic results, checking other components...")
    print(f"Answer box: {result.get('answer_box')}")
    print(f"Related searches: {result.get('related_searches')}")

Quick Diagnostic

# 1. Check API key and account status
curl -s "https://serpapi.com/account.json?api_key=$SERPAPI_API_KEY" | jq '{
  plan: .plan_name, used: .this_month_usage, remaining: .plan_searches_left
}'

# 2. Test basic search
curl -s "https://serpapi.com/search.json?q=test&engine=google&api_key=$SERPAPI_API_KEY" \
  | jq '.search_metadata.status'

# 3. Check search archive (last 10 searches)
curl -s "https://serpapi.com/searches.json?api_key=$SERPAPI_API_KEY" \
  | jq '.[0:3] | .[] | {id: .id, status: .status, query: .search_parameters.q}'

Error Handling

Error Retryable Action
Invalid API key No Fix key
Searches exhausted No Upgrade plan
CAPTCHA/blocked Sometimes Change location, wait
Timeout Yes Retry with backoff
Missing parameter No Fix request params
500 server error Yes Retry 2-3 times

Resources

Next Steps

For comprehensive debugging, see serpapi-debug-bundle.