grok-search-cli
v0.1.3
Published
AI-friendly CLI for high-freshness web and X research with Grok search tool.
Downloads
297
Maintainers
Readme
grok-search-cli
把 Grok 对 X 以及 GitHub、arXiv 等高价值公开数据源的访问能力,带到任何 agent 和 shell 工作流里。
这个 CLI 让这套能力可以直接用于 agent 工作流:在处理快速变化的话题时,更容易获得更新鲜的信息,同时显著降低自建和维护搜索能力的成本。
快速开始
先安装:
# 全局安装 CLI
pnpm add -g grok-search-cli然后做一次健康检查:
# 检查当前配置是否可用
grok-search doctor如果本地还没有配置文件,CLI 会自动创建:
~/.config/grok-search-cli/config.json大多数情况下,你只需要填一个从 xAI 获取的 API key:
{
"XAI_API_KEY": "your_xai_api_key"
}如果你使用的是非官方提供商,见下方的配置方式。
然后执行查询:
# 先跑一个最基本的搜索
grok-search "latest xAI updates"如果不想全局安装,也可以通过 npx 运行:
# 不全局安装,直接用 npx 运行
npx grok-search-cli doctor
npx grok-search-cli "latest xAI updates"可以怎么搜
# 看看现在 X 上都在怎么讨论 xAI
grok-search "现在 X 上大家都在怎么讨论 xAI?"# 验证一个刚出现的说法是不是真的
grok-search "有人说 xAI 今天开源了某个模型,这是真的吗?"# 一次找论文和 GitHub 项目
grok-search "找最新的 browser-use agents 相关 arXiv 论文和 GitHub 项目"# 把网页搜索限制在指定站点
grok-search "latest AI SDK updates" \
--allowed-domains=ai-sdk.dev,vercel.com# 按账号和日期限制 X 搜索范围
grok-search "latest xAI status on X" \
--allowed-handles=xai,elonmusk \
--from-date=2026-04-01# 返回适合 agent 消费的 JSON
grok-search "latest xAI updates" --json为什么用它
- 查“现在发生了什么”,而不是赌模型记忆有没有过时
- 一次调用同时看网页和 X
- 终端可直接读,agent 也能吃 JSON
- 可接 xAI、OpenRouter 和兼容代理站
给 Agent 用
这个仓库自带一个可安装 skill:
# 用 skills CLI 安装仓库自带的 skill
npx skills add timzhong1024/grok-search-cli --skill grok-search-cli如果是 Codex,仓库里还带了一份可配套使用的 preset,见 agents/codex.yaml。
可直接用这句触发:
Spawn a grok-research researcher agent with gpt-5.4-mini and low reasoning, then use grok-search for high-freshness web+X research.内置 skill 也可以直接打印到 stdout 后手动安装:
# 把内置 skill 打印出来并手动保存
grok-search skill > ~/.codex/skills/grok-search-cli/SKILL.md配置方式
process.env 的优先级高于 ~/.config/grok-search-cli/config.json,因此在临时覆盖配置时,优先使用 shell 环境变量。
默认情况下,CLI 会使用 xAI 官方地址和内置默认模型 grok-4-1-fast-non-reasoning。
| 字段 | 是否必填 | 默认行为 | 什么时候可能要改 |
| --- | --- | --- | --- |
| XAI_API_KEY | 是 | 无默认值 | 所有场景都必须提供 |
| XAI_MODEL | 否 | 使用 grok-4-1-fast-non-reasoning | 当你想切换到其他 Grok 模型时 |
| XAI_BASE_URL | 否 | 使用 xAI 官方地址 | 当你要接 OpenRouter 或其他兼容网关时 |
如果你想手动覆盖模型,可以这样写:
{
"XAI_API_KEY": "your_xai_api_key",
"XAI_MODEL": "grok-4-1-fast-non-reasoning"
}注意:不同服务商使用的 model id 不一定一样。xAI 官方、OpenRouter、以及其他兼容网关,通常都需要各自对应的模型名。切换服务商时,不要直接沿用原来的 model id。
OpenRouter 示例
{
"XAI_API_KEY": "your_openrouter_api_key",
"XAI_MODEL": "x-ai/grok-4.1-fast",
"XAI_BASE_URL": "https://openrouter.ai/api/v1"
}其他兼容网关示例
{
"XAI_API_KEY": "your_proxy_api_key",
"XAI_MODEL": "grok-4-fast",
"XAI_BASE_URL": "https://yunwu.ai/v1",
"XAI_COMPAT_MODE": true
}像 yunwu 这类兼容网关,通常需要设置 XAI_COMPAT_MODE=true。
服务选择建议
推荐顺序:
- 优先使用 xAI 官方服务。这是
web_search和x_search最直接、最稳定的路径。 - 如果不直连 xAI,优先用 OpenRouter。这是这里最稳的非官方选项。
- 第三方兼容网关,例如 yunwu,更适合作为兼容兜底。很多代理站只暴露
/chat/completions,是否真的能搜索,取决于站点是否在内部为你开启了 web search。
推荐模型:
| 服务商 | 推荐模型 | 说明 |
| --- | --- | --- |
| xAI 官方 | grok-4-1-fast-non-reasoning | 这是当前 CLI 的默认模型,也是 web_search 和 x_search 支持最完整的路径 |
| OpenRouter | x-ai/grok-4.1-fast | 通过 OpenRouter 接入时,优先用这个 |
| 其他兼容网关,例如 yunwu | 以网关实际支持的 model id 为准 | 比如 yunwu 示例里使用 grok-4-fast |
搜索模式
xAI 官方
直接连接 xAI 官方服务时使用。
- 同时支持 Web Search 和 X Search
- 支持网页域名过滤、X 账号过滤、日期过滤,以及图片或视频理解选项
- 这是能力最完整的模式
OpenRouter
当 XAI_BASE_URL 指向 openrouter.ai 时使用。
- 支持通过 OpenRouter 的服务端搜索工具进行网页搜索
- 只支持网页域名过滤
- 不支持配置 X 专属配置,例如账号、日期、以及图片或视频理解选项
其他兼容网关
当你通过其他 OpenAI-compatible 网关接入时使用。
- 使用网关提供的兼容调用路径
- 是否真的搜索、怎么搜索,由中转站决定
- 不支持所有搜索高级配置
CLI 参考
# 检查当前配置是否可用
grok-search doctor# 把内置 skill 打印到 stdout
grok-search skill# 查看完整命令帮助
grok-search --help本地开发
本地如果要走 .env,pnpm dev 已经默认走 dotenvx:
# 开发时通过 dotenvx 运行 TypeScript 入口
pnpm install
pnpm dev "latest xAI updates" --verbose