Install
openclaw skills install smart-search-fallback统一搜索入口 — 智能路由 + 自动降级。根据查询场景自动选择最优工具(Serper/Google、OpenCLI、多引擎聚合、深度爬虫、远程浏览器、直接抓取等),任一工具失败时自动降级到下一优先级。触发条件:用户要求搜索信息、查找网页、获取最新资讯、验证事实、搜索中英文内容、或任何需要联网获取信息的场景。当搜索相关的所有场景都使用此 Skill,包括 web-search-plus、multi-search-engine、crawl4ai、firecrawl、opencli、web_fetch 等工具的协调调用。
openclaw skills install smart-search-fallback统一搜索入口。一句话:永远不因缺 API Key 放弃搜索。
T1: web-search-plus (Serper) ← 结构化搜索,默认首选(2500次/月)
↓ 额度用尽 / API 错误
T2: opencli google search ← 免 Key,直接调 Google,结构化 JSON ✅ 实测可用
↓ 失败
T3: multi-search-engine (crawl4ai) ← 爬取百度/搜狗等国内引擎,免 Key
↓ 验证码拦截
T4: crawl4ai (深度爬取) ← 指定 URL 完整抓取,JS 渲染支持
↓ 失败
T5: firecrawl-cli ← 远程浏览器反爬(需 API Key)
↓ 无 Key 或额度用完
T6: web_fetch ← 已知 URL 直接提取 Markdown
↓ sandbox 网络限制 / 失败
T7: OpenCLI 其他搜索 ← zhihu search / bilibili search 等垂直搜索
| 场景 | 首选工具 | 说明 |
|---|---|---|
| 英文搜索 / 结构化结果 | T1 web-search-plus | Serper,返回 JSON 结构 |
| 中文内容 / 国内信息 | T2 opencli google | 免 Key,直接调 Google |
| AI 新闻 / 技术动态 | T1→T2 | Serper → opencli google |
| 知乎内容搜索 | T7 opencli zhihu search | 垂直搜索 |
| 深度页面 / JS 渲染 | T4 crawl4ai | 指定 URL 完整抓取 |
| 重度反爬网站 | T5 firecrawl-cli | 远程沙箱 |
| 已知 URL 提取 | T6 web_fetch | 直接给 URL 时 |
python3 skills/web-search-plus/scripts/search.py -q "查询内容" --count 5
opencli google search "查询内容" --limit 5 -f json
python3 -c "
import asyncio
from crawl4ai import AsyncWebCrawler
async def main():
async with AsyncWebCrawler() as c:
r = await c.arun(url='https://www.baidu.com/s?wd=查询内容')
print(r.markdown[:3000])
asyncio.run(main())
"
python3 -c "
import asyncio
from crawl4ai import AsyncWebCrawler
async def main():
async with AsyncWebCrawler() as c:
r = await c.arun(url='https://example.com/article')
print(r.markdown)
asyncio.run(main())
"
firecrawl search "查询内容" --limit 5
web_fetch(url="https://example.com", extractMode="markdown")
opencli zhihu search "查询内容" --limit 5 -f json
opencli bilibili search "查询内容" --limit 5 -f json
opencli hackernews top --limit 5 -f json
当首选工具失败时:
web_search (Brave) — 无 API Key,必然失败| 环境 | T1 | T2 | T3 | T4 | T5 | T6 | T7 |
|---|---|---|---|---|---|---|---|
| 本机(sandbox) | ✅ | ✅ | ✅(百度可爬) | ✅ | ❌(额度完) | ⚠️(部分拦截) | ✅ |
| 其他 VPS | ✅ | ✅ | ✅ | ✅ | ✅(有Key时) | ✅ | ✅ |
sandbox 网络限制:
web_fetch 对部分域名会被拦(Google、部分境外站点)opencli google search "query" # Google 搜索
opencli google news # Google 新闻
opencli google suggest # Google 联想词
opencli google trends # Google 趋势
opencli zhihu search "query" # 知乎搜索
opencli zhihu hot # 知乎热榜
opencli bilibili search "query" # B站搜索
opencli hackernews top # HackerNews 热帖
opencli arxiv search "query" # 学术论文搜索
opencli 36kr search "query" # 36kr 搜索
查看完整命令列表:opencli list -f yaml | grep search
skills/web-search-plus/.envskills/firecrawl-cli/.envskills/multi-search-engine/SKILL.md本 Skill 不包含任何 API Key。所有凭证存储在本地 .env 和 config.json 文件中,不会被打包进 .skill 分享文件。