从 Serper 切到 SERP API:200 行代码 diff 实战

背景

接手一个老项目,原来用 Serper.dev 抓 Google SERP,现在切到 SERP API。两家 API 设计相近,理论上 1-2 天能切完。实际做完,代码 diff 大约 200 行,踩了 4 个坑,记下来给同样要切的人。

API 差异

维度 Serper.dev SerpBase
协议 GET / POST 都行 仅 POST
鉴权 header X-API-KEY(全大写) X-API-Key(大写 X-API + 小写 Key)
Endpoint google.serper.dev/search api.serpbase.dev/google/search
Body 格式 JSON JSON
默认 num 10 10
返回 organic key organic organic
返回 PAA key peopleAlsoAsk(camelCase) people_also_ask(snake_case)
返回 KG key knowledgeGraph knowledge_graph
返回 AI Overview aiOverview ai_overview
Snippet 字段 snippet snippet
错误响应 {"message": "..."} {"status": "error", "message": "...", "request_id": "..."}

JSON 字段命名风格:Serper 是 camelCase,SerpBase 是 snake_case。这是最大差异,大约 60% 的代码差异都来自这里。

实际 diff 例子

Python 调用层

Serper 之前:

python 复制代码
import requests

API_KEY = "your-serper-key"
ENDPOINT = "https://google.serper.dev/search"

def search(query):
    r = requests.post(
        ENDPOINT,
        headers={"X-API-KEY": API_KEY, "Content-Type": "application/json"},
        json={"q": query},
    )
    return r.json()

SerpBase 之后:

python 复制代码
import requests

API_KEY = "your-serpbase-key"
ENDPOINT = "https://api.serpbase.dev/google/search"

def search(query):
    r = requests.post(
        ENDPOINT,
        headers={"X-API-Key": API_KEY, "Content-Type": "application/json"},
        json={"q": query},
    )
    return r.json()

差异:3 行(URL + header name + key 名)。注意 header 大小写不一致 :X-API-KEY vs X-API-Key,这是最容易踩的第一个坑。

业务解析层

Serper 之前:

python 复制代码
def get_organic(data):
    return data.get("organic", [])

def get_paa(data):
    return data.get("peopleAlsoAsk", [])

def get_kg(data):
    return data.get("knowledgeGraph", {})

SerpBase 之后:

python 复制代码
def get_organic(data):
    return data.get("organic", [])

def get_paa(data):
    return data.get("people_also_ask", [])

def get_kg(data):
    return data.get("knowledge_graph", {})

差异:每行只改字段名。grep -r "peopleAlsoAsk\|knowledgeGraph\|aiOverview" . 全文替换即可。

4 个踩过的坑

1. PAA 字段的嵌套结构不同。

Serper 的 peopleAlsoAsk 每项是 {question, snippet, link, title}。SerpBase 的 people_also_ask 多一个 source 字段,有时 PAA 项里直接嵌 link

老代码假设 PAA 每项都有 link,某些 SerpBase 返回里 link 在 source 里,导致 KeyError。改成:

python 复制代码
def get_paa_link(item):
    return item.get("link") or item.get("source", {}).get("link")

2. knowledgeGraph 不再是简单顶层 key。

Serper 的 knowledgeGraph 是平铺对象。SerpBase 的 knowledge_graph 嵌套更深,有些查询返回 knowledge_graph.title / description,有些返回 knowledge_graph.attributes

老代码 kg.get("title") 在 SerpBase 上经常拿到 None。改成:

python 复制代码
def get_kg_title(kg):
    return kg.get("title") or kg.get("name")

3. ai_overview 触发判断的字段不同。

Serper 的 aiOverview 存在就是触发了。SerpBase 的 ai_overview 即使不存在,响应里也可能有 aiOverviewCited 这种 metadata 字段(在某些 query 上)。

判断触发更稳的方法:检查 ai_overview.text 是否非空,不要只看 key 是否存在。

4. error response 的 code 字段。

Serper 错误响应是 {"message": "..."}。SerpBase 是 {"status": "error", "message": "...", "request_id": "..."}

如果你之前用 r.status_code != 200 判断成功,两家都 OK。如果用 r.json().get("success"),Serper 是 True,SerpBase 没有这个字段,要改成 r.json().get("status") == "ok"

request_id 这个字段是 SerpBase 独有的,落库时存下来,出问题查日志直接用。

切换流程(给团队 SOP)

  1. 在独立 branch 上做 API 层改造,业务层暂时兼容两家返回
  2. 跑 1 周平行测试,两家结果对账,差异 < 1% 才推进
  3. 切流量,留 30 天 fallback(Serper 账号别立刻注销)
  4. 删 fallback,清代码

性能差异

我切的项目每天 30,000 搜索,实测:

  • Serper P50:~1.2s
  • SerpBase P50:~1.4s

切完之后 0.2s latency 差异在业务上不可感知(下游还有 LLM 推理 2-3s)。

价格上:同样 30,000 搜索,Serper 30(50/50k),SerpBaseGrowth30(50/50k),SerpBase Growth 30(50/50k),SerpBaseGrowth12(50/125k),节省 60%。

一个意外发现

切完之后,我项目的 credit 不过期(SerpBase 标准包),可以一次性买 1 年的搜索量放着。Serper 同样是预付,但入门包单价高。

如果项目月用量稳定,SerpBase 长期持有更便宜。

总结

切换本身不难,1-2 天工作量。最大的隐藏成本是 JSON 字段命名风格的差异,业务层要全面 grep 替换。其它都是边角问题,跑两周对账都能 catch。

100 次免费试用:serpbase.dev 注册,不用绑卡,跑 1 周平行测试用。

相关推荐
天空属于哈夫克37 天前
打造私域闭环:CRM 如何驱动企微外部客户触达
自动化·企业微信·api
147API8 天前
Fable 5访问暂停后,模型接入层不能再只写死一个模型名
大数据·人工智能·api·claude
Tanshu_API君8 天前
API 聚合网站靠谱吗:深度实测与避坑指南
api·聚合网站
华万通信king9 天前
DocuSign电子签API集成实战:批量发送信封与Webhook回调处理
api·电子签·docusign
Alan_759 天前
京东RESTful商品接口三大异步优化核心
后端·api
崔庆才丨静觅9 天前
Claude Code 对接 NanoBanana MCP
api·claude·mcp
七夜zippoe9 天前
DolphinDB HTTP API接入:RESTful数据推送
网络协议·http·api·restful·dolphindb
乘浪初心11 天前
python调用API接口,免费API调取,学习如何调取API接口并反馈你输入的内容
开发语言·python·api·免费
想要成为糕糕手12 天前
RESTful Todo 任务清单 —— 从零学习前后端
api·restful·bun