Pi 官方文档
快捷键
按键绑定
所有键盘快捷键都可以通过 ~/.pi/agent/keybindings.json 自定义。每个操作都可以绑定一个或多个按键。
配置文件使用的,是 pi 内部同样一套带命名空间的 keybinding id。扩展作者在 keyHint() 和注入的 keybindings 管理器中,也使用这一套。
使用旧版未带命名空间 id(例如 cursorUp 或 expandTools)的旧配置,会在启动时自动迁移为带命名空间的 id。
编辑完 keybindings.json 后,在 pi 里运行 /reload,即可应用更改,无需重启会话。
按键格式
modifier+key,其中修饰键是 ctrl、shift、alt(可组合),按键包括:
- 字母:
a-z - 数字:
0-9 - 特殊按键:
escape、esc、enter、return、tab、space、backspace、delete、insert、clear、home、end、pageUp、pageDown、up、down、left、right - 功能键:
f1-f12 - 符号:
`、-、=、[、]、\、;、'、,、.、/、!、@、#、$、%、^、&、*、(、)、_、+、|、~、{、}、:、<、>、?
修饰键组合:ctrl+shift+x、alt+ctrl+x、ctrl+shift+alt+x、ctrl+1 等。
全部操作
TUI 编辑器光标移动
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
tui.editor.cursorUp | up | 光标上移 |
tui.editor.cursorDown | down | 光标下移 |
tui.editor.cursorLeft | left, ctrl+b | 光标左移 |
tui.editor.cursorRight | right, ctrl+f | 光标右移 |
tui.editor.cursorWordLeft | alt+left, ctrl+left, alt+b | 光标向左跳一个词 |
tui.editor.cursorWordRight | alt+right, ctrl+right, alt+f | 光标向右跳一个词 |
tui.editor.cursorLineStart | home, ctrl+a | 跳到行首 |
tui.editor.cursorLineEnd | end, ctrl+e | 跳到行尾 |
tui.editor.jumpForward | ctrl+] | 向前跳到字符 |
tui.editor.jumpBackward | ctrl+alt+] | 向后跳到字符 |
tui.editor.pageUp | pageUp | 向上翻页 |
tui.editor.pageDown | pageDown | 向下翻页 |
TUI 编辑器删除
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
tui.editor.deleteCharBackward | backspace | 向后删除字符 |
tui.editor.deleteCharForward | delete, ctrl+d | 向前删除字符 |
tui.editor.deleteWordBackward | ctrl+w, alt+backspace | 向后删除一个词 |
tui.editor.deleteWordForward | alt+d, alt+delete | 向前删除一个词 |
tui.editor.deleteToLineStart | ctrl+u | 删除到行首 |
tui.editor.deleteToLineEnd | ctrl+k | 删除到行尾 |
TUI 输入
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
tui.input.newLine | shift+enter | 插入新行 |
tui.input.submit | enter | 提交输入 |
tui.input.tab | tab | Tab / 自动补全 |
TUI 剪切环
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
tui.editor.yank | ctrl+y | 粘贴最近删除的文本 |
tui.editor.yankPop | alt+y | 在 yank 后轮换浏览删除的文本 |
tui.editor.undo | ctrl+- | 撤销上一次编辑 |
TUI 剪贴板与选择
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
tui.input.copy | ctrl+c | 复制选中内容 |
tui.select.up | up | 选择项上移 |
tui.select.down | down | 选择项下移 |
tui.select.pageUp | pageUp | 列表上翻页 |
tui.select.pageDown | pageDown | 列表下翻页 |
tui.select.confirm | enter | 确认选择 |
tui.select.cancel | escape, ctrl+c | 取消选择 |
应用
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
app.interrupt | escape | 取消 / 中止 |
app.clear | ctrl+c | 清空编辑器 |
app.exit | ctrl+d | 退出(编辑器为空时) |
app.suspend | ctrl+z(Windows 上无) | 挂起到后台 |
app.editor.external | ctrl+g | 在外部编辑器中打开($VISUAL 或 $EDITOR) |
app.clipboard.pasteImage | ctrl+v(Windows 上为 alt+v) | 从剪贴板粘贴图片 |
会话
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
app.session.new | (无) | 新建会话(/new) |
app.session.tree | (无) | 打开会话树导航器(/tree) |
app.session.fork | (无) | 分叉当前会话(/fork) |
app.session.resume | (无) | 打开会话恢复选择器(/resume) |
app.session.togglePath | ctrl+p | 切换路径显示 |
app.session.toggleSort | ctrl+s | 切换排序模式 |
app.session.toggleNamedFilter | ctrl+n | 切换仅显示带名称条目的过滤器 |
app.session.rename | ctrl+r | 重命名会话 |
app.session.delete | ctrl+d | 删除会话 |
app.session.deleteNoninvasive | ctrl+backspace | 查询为空时删除会话 |
模型与思考
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
app.model.select | ctrl+l | 打开模型选择器 |
app.model.cycleForward | ctrl+p | 切换到下一个模型 |
app.model.cycleBackward | shift+ctrl+p | 切换到上一个模型 |
app.thinking.cycle | shift+tab | 切换思考级别 |
app.thinking.toggle | ctrl+t | 折叠或展开思考块 |
显示与消息队列
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
app.tools.expand | ctrl+o | 折叠或展开工具输出 |
app.message.followUp | alt+enter | 将后续消息加入队列 |
app.message.dequeue | alt+up | 将队列中的消息恢复到编辑器 |
树导航
| 按键绑定 ID | 默认 | 说明 |
|---|---|---|
app.tree.foldOrUp | ctrl+left, alt+left | 折叠当前分支段,或跳到上一个分段起点 |
app.tree.unfoldOrDown | ctrl+right, alt+right | 展开当前分支段,或跳到下一个分段起点或分支末尾 |
app.tree.editLabel | shift+l | 编辑所选树节点上的标签 |
app.tree.toggleLabelTimestamp | shift+t | 切换树中标签时间戳显示 |
app.tree.filter.default | ctrl+d | 将树过滤器设为默认视图 |
app.tree.filter.noTools | ctrl+t | 切换隐藏工具结果的树过滤器 |
app.tree.filter.userOnly | ctrl+u | 切换仅显示用户消息的树过滤器 |
app.tree.filter.labeledOnly | ctrl+l | 切换仅显示带标签条目的树过滤器 |
app.tree.filter.all | ctrl+a | 切换显示所有条目的树过滤器 |
app.tree.filter.cycleForward | ctrl+o | 向前切换树过滤器 |
app.tree.filter.cycleBackward | shift+ctrl+o | 向后切换树过滤器 |
作用域模型选择器
在作用域模型选择器中使用(通过 /scoped-models 打开)。
| 按键绑定 id | 默认值 | 说明 |
|---|---|---|
app.models.save | ctrl+s | 将当前模型选择保存到设置 |
app.models.enableAll | ctrl+a | 启用所有模型(或当前搜索匹配到的所有模型) |
app.models.clearAll | ctrl+x | 清除所有模型(或当前搜索匹配到的所有模型) |
app.models.toggleProvider | ctrl+p | 切换当前 Provider(模型提供方)的所有模型 |
app.models.reorderUp | alt+up | 在轮循顺序中上移所选模型 |
app.models.reorderDown | alt+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"]
}