Skip to main content

AutoSH — 一句中文,自动补命令

Project description

AutoSH / ah

AutoSH logo

stars python zsh bash license updated

卧槽,命令忘了怎么办!

别急:一句中文,秒出命令

AutoSH(ah)是给中文程序员的终端 AI 助手。在 zsh 里写中文,按一下就出命令。

天下苦 Bash 久已,快来 ah 一下。

两种模式

快捷键 模式 效果
Ctrl+G 极速 直接出命令,一步到位
Ctrl+/ 选择 弹出三个候选 + 中文解释,看懂了选

Ctrl+/ 在部分终端里等价于 Ctrl+_;如果 Ctrl+/ 没反应,用 Ctrl+_ 触发同一个选择模式。

$ docker 清理无用镜像         # ← 在终端里直接写中文
# 按 Ctrl+G → 直接变成:
$ docker system prune -f      # ← 回车就跑

安装

一键安装:

curl -fsSL https://wang-h.github.io/autosh/install.sh | bash

从 PyPI 安装:

uv tool install autosh-ah
# 或: pip install autosh-ah

从 GitHub 安装:

uv tool install git+https://github.com/wang-h/autosh.git
# 或: pip install git+https://github.com/wang-h/autosh.git

然后配 Key + 切模型 + 注入 Shell:

ah config set api_key <your-api-key>
ah config set provider deepseek   # 支持: kimi / minimax / qwen / glm
ah init zsh                       # 或 ah init bash
source ~/.zshrc

装完就可以在终端里用了——zsh 和 bash 都支持ah init 会自动识别。

使用

装完就能用,zsh 和 bash 都行。直接在终端里写中文,按快捷键:

# Ctrl+G → 极速,直接出
$ docker 清理无用镜像        # 你写的
$ docker system prune -f     # ah 替换的,回车就跑

# Ctrl+/ → 三选一,带解释
$ git 回退上一次提交
  [1] git reset --soft HEAD~1  撤销提交但保留修改
  [2] git reset --mixed HEAD~1  撤销提交和暂存
  [3] git revert HEAD           生成新提交来撤销
  Pick [1-3]:                  # 回车默认选 1

命令

命令 说明
ah init <zsh|bash> 安装 Shell 集成
ah config 查看当前配置
ah config set <key> <value> 设置配置项(切 provider 一键切模型)
ah suggest <中文描述> 直接生成命令建议
ah daemon <start|status|stop> 管理本地常驻进程(默认自动启动)
ah doctor 检查环境配置
ah doctor --keys 测试当前终端实际收到的快捷键编码

配置

~/.autosh/config.yaml

provider: deepseek
model: deepseek-v4-flash
base_url: https://api.deepseek.com/anthropic
api_key: sk-xxx
配置项 说明
provider AI 提供商:deepseek / kimi / minimax / qwen / glm
model 模型名称(切 provider 自动更新)
base_url API 地址(切 provider 自动更新)
api_key API 密钥
ah config set provider kimi      # 切到 Kimi
ah config set provider deepseek  # 切回来

自定义快捷键

zsh 编辑 ~/.autosh/autosh.zsh

bindkey -M emacs '^G' autosh-fast
bindkey -M viins '^G' autosh-fast
bindkey -M emacs '^_' autosh-pick
bindkey -M viins '^_' autosh-pick

bash 编辑 ~/.autosh/autosh.bash

bind -m emacs -x '"\C-g": _autosh_fast'
bind -m vi-insert -x '"\C-g": _autosh_fast'
bind -m emacs -x '"\C-_": _autosh_pick'
bind -m vi-insert -x '"\C-_": _autosh_pick'

原理

读取当前命令行缓冲区 → 发送给 AI API → 模型生成命令 → 替换回命令行。不上传命令历史。

环境要求

  • Python 3.11+
  • zsh 或 bash
  • 任一提供商 API Key(DeepSeek / Kimi / MiniMax / Qwen / GLM)

Star History

Star History Chart

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

autosh_ah-0.1.2.tar.gz (37.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

autosh_ah-0.1.2-py3-none-any.whl (15.5 kB view details)

Uploaded Python 3

File details

Details for the file autosh_ah-0.1.2.tar.gz.

File metadata

  • Download URL: autosh_ah-0.1.2.tar.gz
  • Upload date:
  • Size: 37.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for autosh_ah-0.1.2.tar.gz
Algorithm Hash digest
SHA256 51b74c19713c57844961248ddc061be022f24fd724a3381762f835c34c645796
MD5 2f456d51e603e06827416c8449704852
BLAKE2b-256 a5c660538cabbe2c71937d52fae84d50e0885da2877c799a86b329f907557c18

See more details on using hashes here.

File details

Details for the file autosh_ah-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: autosh_ah-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 15.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for autosh_ah-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d7fb29f374ed1a288f898c8b5996ba936a935c6a830e11da2c5a64e313727e4a
MD5 5bc066d374d6c739eaf24037b30ff9df
BLAKE2b-256 6fc1b825434fa2de99b03fa122180f30b4eb180b6c3f12e1ea52a6a6f288d7a4

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page