使用 Pi
本页汇总不适合放在快速开始页上的日常用法细节。

界面有四个主要区域:
- 启动页眉 - 快捷键、已加载的上下文文件、提示词模板、技能和扩展
- 消息 - 用户消息、助手回复、工具调用、工具结果、通知、错误和扩展 UI
- 编辑器 - 输入区域;边框颜色表示当前思考级别
- 页脚 - 工作目录、会话名称、token/缓存用量、费用、上下文用量和当前模型
编辑器可被内置 UI(如 /settings)或自定义扩展 UI 临时替换。
| 功能 | 用法 |
|---|---|
| 文件引用 | 输入 @ 模糊搜索项目文件 |
| 路径补全 | 按 Tab 补全路径 |
| 多行输入 | Shift+Enter,或在 Windows Terminal 中使用 Ctrl+Enter |
| 图片 | 用 Ctrl+V 粘贴、在 Windows 上用 Alt+V,或拖入终端 |
| Shell 命令 | !command 运行并将输出发送给模型 |
| 隐藏 Shell 命令 | !!command 运行但不将输出发送给模型 |
| 外部编辑器 | Ctrl+G 打开 $VISUAL 或 $EDITOR |
有关所有快捷键和自定义,请参阅 Keybindings。
在编辑器中输入 / 打开命令补全。扩展可注册自定义命令,技能可通过 /skill:name 使用,提示词模板通过 /templatename 展开。
| 命令 | 描述 |
|---|---|
/login、/logout | 管理 OAuth 或 API 密钥凭据 |
/model | 切换模型 |
/scoped-models | 启用/禁用用于 Ctrl+P 循环的模型 |
/settings | 思考级别、主题、消息投递、传输 |
/resume | 从之前的会话中选择 |
/new | 开始新会话 |
/name <name> | 设置会话显示名称 |
/session | 显示会话文件、ID、消息、token 和费用 |
/tree | 跳转到会话中的任意点并从该处继续 |
/fork | 从之前的用户消息创建新会话 |
/clone | 将当前活动分支复制到新会话 |
/compact [prompt] | 手动压缩上下文,可选自定义指令 |
/copy | 将最后一条助手消息复制到剪贴板 |
/export [file] | 将会话导出为 HTML |
/share | 上传为私有 GitHub gist 并生成可分享的 HTML 链接 |
/reload | 重新加载快捷键、扩展、技能、提示词和上下文文件 |
/hotkeys | 显示所有键盘快捷键 |
/changelog | 显示版本历史 |
/quit | 退出 pi |
你可以在代理仍在工作时提交消息:
- Enter 将消息加入引导队列,在当前助手轮次完成工具调用执行后投递。
- Alt+Enter 将消息加入后续队列,在代理完成所有工作后投递。
- Escape 中止并将队列中的消息恢复到编辑器。
- Alt+Up 将队列中的消息取回编辑器。
在 Windows Terminal 中,Alt+Enter 默认用于全屏。若希望 pi 接收该快捷键,请按 Terminal setup 中的说明重新映射。
在 Settings 中使用 steeringMode 和 followUpMode 配置投递方式。
会话自动保存到 ~/.pi/agent/sessions/,按工作目录组织。
pi -c # 继续最近的会话pi -r # 浏览并选择会话pi --no-session # 临时模式;不保存pi --name "my task" # 启动时设置会话显示名称pi --session <path|id> # 使用特定会话文件或会话 IDpi --fork <path|id> # 将会话分叉到新会话文件有用的会话命令:
/session显示当前会话文件和 ID。/tree导航文件内会话树并可摘要已放弃的分支。/fork从较早的用户消息创建新会话。/clone将当前活动分支复制到新会话文件。/compact摘要较旧消息以释放上下文。
详情请参阅 Sessions 和 Compaction。
Pi 在启动时从以下位置加载 AGENTS.md 或 CLAUDE.md:
~/.pi/agent/AGENTS.md用于全局指令- 从当前工作目录向上遍历的父目录
- 当前目录
使用上下文文件存放项目约定、命令、安全规则和偏好。使用 --no-context-files 或 -nc 禁用加载。
系统提示词文件
Section titled “系统提示词文件”用以下文件替换默认系统提示词:
.pi/SYSTEM.md用于项目~/.pi/agent/SYSTEM.md用于全局
在上述任一位置使用 APPEND_SYSTEM.md 可在不替换默认提示词的情况下追加内容。
在交互式启动时,若项目文件夹包含项目本地设置、资源或项目 .agents/skills,且在 ~/.pi/agent/trust.json 中对该文件夹或其父文件夹没有已保存的决定,pi 会在信任前询问。
信任项目后,pi 可加载 .pi/settings.json 和 .pi 资源、安装缺失的项目包并执行项目扩展。
在信任决定之前,pi 仅加载上下文文件、用户/全局扩展和 CLI -e 扩展,以便它们能处理 project_trust 事件。项目本地扩展、项目包管理的扩展和项目设置仅在项目被信任后加载。切换到来自不同 cwd 且当前进程尚未解析信任的会话时,同样适用此划分。
非交互模式(-p、--mode json 和 --mode rpc)不显示信任提示。若无适用的已保存信任决定,它们使用全局设置中的 defaultProjectTrust:ask(默认)和 never 会忽略这些项目资源,而 always 会信任它们。传递 --approve/-a 或 --no-approve/-na 可覆盖单次运行的项目信任。
若无扩展或已保存决定适用,defaultProjectTrust 控制回退行为。在 ~/.pi/agent/settings.json 中将其设为 "ask"、"always" 或 "never",或通过 /settings 更改。
pi config 和包命令使用相同的项目信任流程,但 pi update 从不提示。传递 --approve 可信任单次命令的项目本地设置,或 --no-approve 忽略它们。
在交互模式下使用 /trust 保存项目信任决定供未来会话使用,包括对直接父文件夹的信任。它仅写入 ~/.pi/agent/trust.json;当前会话不会重新加载,因此需重启 pi 使更改生效。
导出和分享会话
Section titled “导出和分享会话”使用 /export [file] 将会话写入 HTML。
使用 /share 上传私有 GitHub gist 并生成可分享的 HTML 链接。
若你将 pi 用于开源工作并希望发布会话以供模型、提示词、工具和评估研究,请参阅 badlogic/pi-share-hf。它会将会话发布到 Hugging Face 数据集。
CLI 参考
Section titled “CLI 参考”pi [options] [@files...] [messages...]pi install <source> [-l] # 安装包,-l 表示项目本地pi remove <source> [-l] # 移除包pi uninstall <source> [-l] # remove 的别名pi update [source|self|pi] # 仅更新 pi,或更新一个包源pi update --all # 更新 pi 和包;协调固定的 git refpi update --extensions # 仅更新包;协调固定的 git refpi update --self # 仅更新 pipi update --extension <src> # 更新一个包pi list # 列出已安装的包pi config # 启用/禁用包资源这些命令管理 pi 包,pi update 可更新 pi CLI 安装。要卸载 pi 本身,请参阅 Quickstart。pi config 和项目包命令接受 --approve/--no-approve,以信任或忽略单次命令的项目本地设置。pi update 从不提示项目信任。
有关包源和安全说明,请参阅 Pi Packages。
| 标志 | 描述 |
|---|---|
| default | 交互模式 |
-p、--print | 打印响应并退出 |
--mode json | 将所有事件输出为 JSON 行;请参阅 JSON mode |
--mode rpc | 通过 stdin/stdout 的 RPC 模式;请参阅 RPC mode |
--export <in> [out] | 将会话导出为 HTML |
在 print 模式下,pi 还会读取管道 stdin 并将其合并到初始提示词中:
cat README.md | pi -p "Summarize this text"| 选项 | 描述 |
|---|---|
--provider <name> | 提供商,如 anthropic、openai 或 google |
--model <pattern> | 模型模式或 ID;支持 provider/id 和可选的 :<thinking> |
--api-key <key> | API 密钥,覆盖环境变量 |
--thinking <level> | off、minimal、low、medium、high、xhigh |
--models <patterns> | 用于 Ctrl+P 循环的逗号分隔模式 |
--list-models [search] | 列出可用模型 |
| 选项 | 描述 |
|---|---|
-c、--continue | 继续最近的会话 |
-r、--resume | 浏览并选择会话 |
--session <path|id> | 使用特定会话文件或部分 UUID |
--fork <path|id> | 将会话文件或部分 UUID 分叉到新会话 |
--session-dir <dir> | 自定义会话存储目录 |
--no-session | 临时模式;不保存 |
--name <name>、-n <name> | 启动时设置会话显示名称 |
| 选项 | 描述 |
|---|---|
--tools <list>、-t <list> | 允许列表中的特定内置、扩展和自定义工具 |
--exclude-tools <list>、-xt <list> | 禁用特定内置、扩展和自定义工具 |
--no-builtin-tools、-nbt | 禁用内置工具但保留扩展/自定义工具 |
--no-tools、-nt | 禁用所有工具 |
内置工具:read、bash、edit、write、grep、find、ls。
| 选项 | 描述 |
|---|---|
-e、--extension <source> | 从路径、npm 或 git 加载扩展;可重复 |
--no-extensions | 禁用扩展发现 |
--skill <path> | 加载技能;可重复 |
--no-skills | 禁用技能发现 |
--prompt-template <path> | 加载提示词模板;可重复 |
--no-prompt-templates | 禁用提示词模板发现 |
--theme <path> | 加载主题;可重复 |
--no-themes | 禁用主题发现 |
--no-context-files、-nc | 禁用 AGENTS.md 和 CLAUDE.md 发现 |
将 --no-* 与显式标志组合,可忽略设置并精确加载所需内容。示例:
pi --no-extensions -e ./my-extension.ts| 选项 | 描述 |
|---|---|
--system-prompt <text> | 替换默认提示词;上下文文件和技能仍会追加 |
--append-system-prompt <text> | 追加到系统提示词 |
--verbose | 强制详细启动 |
-a、--approve | 本次运行信任项目本地文件 |
-na、--no-approve | 本次运行忽略项目本地文件 |
-h、--help | 显示帮助 |
-v、--version | 显示版本 |
在文件前加 @ 将其包含在消息中:
pi @prompt.md "Answer this"pi -p @screenshot.png "What's in this image?"pi @code.ts @test.ts "Review these files"# 带初始提示词的交互模式pi "List all .ts files in src/"
# 非交互pi -p "Summarize this codebase"
# 带管道 stdin 的非交互cat README.md | pi -p "Summarize this text"
# 命名的一次性会话pi --name "release audit" -p "Audit this repository"
# 不同模型pi --provider openai --model gpt-4o "Help me refactor"
# 带提供商前缀的模型pi --model openai/gpt-4o "Help me refactor"
# 带思考级别简写的模型pi --model sonnet:high "Solve this complex problem"
# 限制模型循环pi --models "claude-*,gpt-4o"
# 只读模式pi --tools read,grep,find,ls -p "Review the code"
# 禁用某个扩展或内置工具,同时保留其余可用pi --exclude-tools ask_question| 变量 | 描述 |
|---|---|
PI_CODING_AGENT_DIR | 覆盖配置目录;默认为 ~/.pi/agent |
PI_CODING_AGENT_SESSION_DIR | 覆盖会话存储目录;被 --session-dir 覆盖 |
PI_PACKAGE_DIR | 覆盖包目录,适用于 Nix/Guix store 路径 |
PI_OFFLINE | 禁用启动时的网络操作,包括更新检查、包更新检查和安装/更新遥测 |
PI_SKIP_VERSION_CHECK | 跳过启动时的 Pi 版本更新检查。这会阻止对 pi.dev 最新版本的请求 |
PI_TELEMETRY | 覆盖安装/更新遥测和提供商归因头:1/true/yes 或 0/false/no。这不会禁用更新检查 |
PI_CACHE_RETENTION | 设为 long 以在支持处延长提示词缓存 |
VISUAL、EDITOR | Ctrl+G 的外部编辑器 |
Pi 保持核心精简,将特定于工作流的行为推入扩展、技能、提示词模板和包。
它有意不包含内置 MCP、子代理、权限弹窗、计划模式、待办事项或后台 bash。你可以将这些工作流构建或安装为扩展或包,或使用容器和 tmux 等外部工具。
完整理由请参阅博客文章。