AI 编程教程中文版
官方教程中文版CLI 工作流

CLI reference

Gemini CLI 常用启动方式、参数、非交互式调用、session resume、model、sandbox、approval mode 和输出格式。

📖 本篇术语速查表
英文 / 缩写中文一句话解释
CLI reference命令参考Gemini CLI 的完整命令清单。
按职责查by purpose按用途定位命令而非通读。
常用入口common最高频的几个命令。

不想读完?把下面这段提示词丢给 AI 帮你跑完——帮你按职责快速定位需要的 Gemini CLI 命令。

你是 Gemini CLI 命令查询顾问。

【角色】
Gemini CLI 命令查询顾问,按最小够用、安全优先的原则给可落地方案,每条结论落到能照做的步骤或示例。

【输入】
- 我想完成的操作:___
- 属于哪类(会话 / 文件 / 工具 / 配置):___
- 熟练度:___
- 运行环境:___

【工作流程】
1. 把操作归到命令类别
2. 指向对应命令
3. 给最小可用示例
4. 提示相关命令

【输出规范】
▌一、操作归类
▌二、对应命令
▌三、可用示例
▌四、相关命令

【硬约束】
- 命令以官方 reference 为准
- 示例能直接跑
- 高危命令提醒确认
- 不要替我臆测情况或编造不存在的命令,信息不全先问清
- 不确定的命令或参数一律以官方文档为准,禁止照搬过时写法
- 给的每条结论都要落到具体可照做的步骤或示例,不停留在「建议」「考虑一下」这类没法直接执行的空泛表述

Gemini CLI 的命令行入口分两类:交互式会话用于持续协作,非交互式 prompt 用于脚本和自动化。不要把 CLI reference 当成参数长表背诵;先掌握运行位置、上下文输入、权限模式和输出格式。

先记 4 个入口gemini 进入交互;gemini -p 一次性执行;gemini -r latest 恢复最近会话;cat file | gemini 处理管道输入。真实项目先用默认批准模式,不要第一天就开 yolo

1. 常用启动方式

gemini
gemini -p "summarize README.md"
gemini "explain this project"
cat logs.txt | gemini
gemini -i "What is the purpose of this project?"
gemini -r "latest"
gemini -r "latest" "Check for type errors"
gemini -r "<session-id>" "Finish this PR"
gemini update

这些入口的区别:

入口适合场景注意
gemini持续交互、真实项目理解和修改会保留会话上下文
gemini -p "..."一次性回答、脚本、CI要明确输出格式和退出码处理
`cat filegemini`管道输入、日志解释、批处理
gemini -r latest恢复最近 session先确认是不是当前项目的 session
gemini update更新 CLI团队环境要先确认版本策略
flowchart TD
    Need["我要用 Gemini CLI"] --> Interactive{"需要持续对话?"}
    Interactive -->|是| Repl["gemini"]
    Interactive -->|否| Script{"脚本或 CI?"}
    Script -->|是| Prompt["gemini -p + output format"]
    Script -->|否| Pipe{"已有 stdin 输入?"}
    Pipe -->|是| Stdin["cat file | gemini"]
    Pipe -->|否| Resume{"继续旧会话?"}
    Resume -->|是| Session["gemini -r latest"]
    Resume -->|否| Repl

    style Prompt fill:#fef3c7,stroke:#f59e0b
    style Session fill:#dbeafe,stroke:#3b82f6

2. 常用参数

参数用途
--model / -m指定模型或模型 alias
--prompt / -p非交互式执行 prompt
--prompt-interactive / -i先执行 prompt,再继续交互
--resume / -r恢复历史 session
--sandbox / -s启用 sandbox
--approval-mode设置工具执行批准模式
--include-directories把额外目录加入 workspace
--output-format / -o输出 text / json / stream-json
--extensions / -e指定启用 extension
--allowed-mcp-server-names限制可用 MCP server

参数优先级很高:命令行参数用于当前 session,会覆盖部分配置文件设置。临时试验可以用参数;团队默认行为应该沉淀到配置和文档里。

3. approval mode

当前官方配置文档把 --approval-mode 解释为工具调用批准模式,常见值是 defaultauto_edityolo。Plan mode 另有专门页面,不要把它当成长期自动批准策略。

模式使用建议
default日常默认,先确认再执行
auto_edit小范围编辑可考虑,但要看 diff
yolo只适合低风险临时目录,不适合真实项目

不要在真实项目默认使用 yolo:生产仓库、含密钥目录、部署脚本目录、数据库迁移和客户数据目录都不适合跳过确认。需要自动化时,也应该先限制目录、工具和命令。

4. 输出格式和脚本化

非交互式任务优先使用结构化输出:

gemini -p "Explain this repository" --output-format json

长任务监控可以按官方 README 的 stream-json 方式处理事件流;但脚本里要写清失败处理、超时、重试和日志脱敏,不要只管拿到一段文本。

5. model alias

官方 cheatsheet 中列出 autoproflashflash-lite 等 alias。具体解析到哪个模型会随官方实现变化,以当前官方文档和 CLI 输出为准。

模型 alias 是便利入口,不是长期契约。教程和团队规则里不要硬写“某个 alias 一定等于某个模型版本”;需要固定模型时,回模型选择章节和官方 CLI 输出核验。

6. 接下来去哪

官方来源

本页目录