Pi 官方文档

快捷键

按键绑定

所有键盘快捷键都可以通过 ~/.pi/agent/keybindings.json 自定义。每个操作都可以绑定一个或多个按键。

配置文件使用的,是 pi 内部同样一套带命名空间的 keybinding id。扩展作者在 keyHint() 和注入的 keybindings 管理器中,也使用这一套。

使用旧版未带命名空间 id(例如 cursorUpexpandTools)的旧配置,会在启动时自动迁移为带命名空间的 id。

编辑完 keybindings.json 后,在 pi 里运行 /reload,即可应用更改,无需重启会话。

按键格式

modifier+key,其中修饰键是 ctrlshiftalt(可组合),按键包括:

  • 字母: a-z
  • 数字: 0-9
  • 特殊按键: escapeescenterreturntabspacebackspacedeleteinsertclearhomeendpageUppageDownupdownleftright
  • 功能键: f1-f12
  • 符号: `-=[]\;',./!@#$%^&*()_+|~{}:<>?

修饰键组合:ctrl+shift+xalt+ctrl+xctrl+shift+alt+xctrl+1 等。

全部操作

TUI 编辑器光标移动

按键绑定 ID默认说明
tui.editor.cursorUpup光标上移
tui.editor.cursorDowndown光标下移
tui.editor.cursorLeftleft, ctrl+b光标左移
tui.editor.cursorRightright, ctrl+f光标右移
tui.editor.cursorWordLeftalt+left, ctrl+left, alt+b光标向左跳一个词
tui.editor.cursorWordRightalt+right, ctrl+right, alt+f光标向右跳一个词
tui.editor.cursorLineStarthome, ctrl+a跳到行首
tui.editor.cursorLineEndend, ctrl+e跳到行尾
tui.editor.jumpForwardctrl+]向前跳到字符
tui.editor.jumpBackwardctrl+alt+]向后跳到字符
tui.editor.pageUppageUp向上翻页
tui.editor.pageDownpageDown向下翻页

TUI 编辑器删除

按键绑定 ID默认说明
tui.editor.deleteCharBackwardbackspace向后删除字符
tui.editor.deleteCharForwarddelete, ctrl+d向前删除字符
tui.editor.deleteWordBackwardctrl+w, alt+backspace向后删除一个词
tui.editor.deleteWordForwardalt+d, alt+delete向前删除一个词
tui.editor.deleteToLineStartctrl+u删除到行首
tui.editor.deleteToLineEndctrl+k删除到行尾

TUI 输入

按键绑定 ID默认说明
tui.input.newLineshift+enter插入新行
tui.input.submitenter提交输入
tui.input.tabtabTab / 自动补全

TUI 剪切环

按键绑定 ID默认说明
tui.editor.yankctrl+y粘贴最近删除的文本
tui.editor.yankPopalt+y在 yank 后轮换浏览删除的文本
tui.editor.undoctrl+-撤销上一次编辑

TUI 剪贴板与选择

按键绑定 ID默认说明
tui.input.copyctrl+c复制选中内容
tui.select.upup选择项上移
tui.select.downdown选择项下移
tui.select.pageUppageUp列表上翻页
tui.select.pageDownpageDown列表下翻页
tui.select.confirmenter确认选择
tui.select.cancelescape, ctrl+c取消选择

应用

按键绑定 ID默认说明
app.interruptescape取消 / 中止
app.clearctrl+c清空编辑器
app.exitctrl+d退出(编辑器为空时)
app.suspendctrl+z(Windows 上无)挂起到后台
app.editor.externalctrl+g在外部编辑器中打开($VISUAL$EDITOR
app.clipboard.pasteImagectrl+v(Windows 上为 alt+v从剪贴板粘贴图片

会话

按键绑定 ID默认说明
app.session.new(无)新建会话(/new
app.session.tree(无)打开会话树导航器(/tree
app.session.fork(无)分叉当前会话(/fork
app.session.resume(无)打开会话恢复选择器(/resume
app.session.togglePathctrl+p切换路径显示
app.session.toggleSortctrl+s切换排序模式
app.session.toggleNamedFilterctrl+n切换仅显示带名称条目的过滤器
app.session.renamectrl+r重命名会话
app.session.deletectrl+d删除会话
app.session.deleteNoninvasivectrl+backspace查询为空时删除会话

模型与思考

按键绑定 ID默认说明
app.model.selectctrl+l打开模型选择器
app.model.cycleForwardctrl+p切换到下一个模型
app.model.cycleBackwardshift+ctrl+p切换到上一个模型
app.thinking.cycleshift+tab切换思考级别
app.thinking.togglectrl+t折叠或展开思考块

显示与消息队列

按键绑定 ID默认说明
app.tools.expandctrl+o折叠或展开工具输出
app.message.followUpalt+enter将后续消息加入队列
app.message.dequeuealt+up将队列中的消息恢复到编辑器

树导航

按键绑定 ID默认说明
app.tree.foldOrUpctrl+left, alt+left折叠当前分支段,或跳到上一个分段起点
app.tree.unfoldOrDownctrl+right, alt+right展开当前分支段,或跳到下一个分段起点或分支末尾
app.tree.editLabelshift+l编辑所选树节点上的标签
app.tree.toggleLabelTimestampshift+t切换树中标签时间戳显示
app.tree.filter.defaultctrl+d将树过滤器设为默认视图
app.tree.filter.noToolsctrl+t切换隐藏工具结果的树过滤器
app.tree.filter.userOnlyctrl+u切换仅显示用户消息的树过滤器
app.tree.filter.labeledOnlyctrl+l切换仅显示带标签条目的树过滤器
app.tree.filter.allctrl+a切换显示所有条目的树过滤器
app.tree.filter.cycleForwardctrl+o向前切换树过滤器
app.tree.filter.cycleBackwardshift+ctrl+o向后切换树过滤器

作用域模型选择器

在作用域模型选择器中使用(通过 /scoped-models 打开)。

按键绑定 id默认值说明
app.models.savectrl+s将当前模型选择保存到设置
app.models.enableAllctrl+a启用所有模型(或当前搜索匹配到的所有模型)
app.models.clearAllctrl+x清除所有模型(或当前搜索匹配到的所有模型)
app.models.toggleProviderctrl+p切换当前 Provider(模型提供方)的所有模型
app.models.reorderUpalt+up在轮循顺序中上移所选模型
app.models.reorderDownalt+down在轮循顺序中下移所选模型

自定义配置

创建 ~/.pi/agent/keybindings.json

{
  "tui.editor.cursorUp": ["up", "ctrl+p"],
  "tui.editor.cursorDown": ["down", "ctrl+n"],
  "tui.editor.deleteWordBackward": ["ctrl+w", "alt+backspace"]
}

每个动作都可以配置单个按键或按键数组。用户配置会覆盖默认值。

在原生 Windows 上,app.suspend 默认没有绑定,因为 Windows 终端不支持 Unix 的作业控制。如果你手动绑定它,pi 会显示状态消息,而不是挂起。在 WSL 中,Linux 下正常的 ctrl+z/fg 行为仍然适用。

Emacs 示例

{
  "tui.editor.cursorUp": ["up", "ctrl+p"],
  "tui.editor.cursorDown": ["down", "ctrl+n"],
  "tui.editor.cursorLeft": ["left", "ctrl+b"],
  "tui.editor.cursorRight": ["right", "ctrl+f"],
  "tui.editor.cursorWordLeft": ["alt+left", "alt+b"],
  "tui.editor.cursorWordRight": ["alt+right", "alt+f"],
  "tui.editor.deleteCharForward": ["delete", "ctrl+d"],
  "tui.editor.deleteCharBackward": ["backspace", "ctrl+h"],
  "tui.input.newLine": ["shift+enter", "ctrl+j"]
}

Vim 示例

{
  "tui.editor.cursorUp": ["up", "alt+k"],
  "tui.editor.cursorDown": ["down", "alt+j"],
  "tui.editor.cursorLeft": ["left", "alt+h"],
  "tui.editor.cursorRight": ["right", "alt+l"],
  "tui.editor.cursorWordLeft": ["alt+left", "alt+b"],
  "tui.editor.cursorWordRight": ["alt+right", "alt+w"]
}

Pi 官方文档中文整理 · 机器初译,待人工校对

本文基于官方 MIT 文档翻译整理,不代表 pi.dev 官方中文站。同步 commit:8b97e75c,同步时间:2026/6/20

查看官方原文