Skip to content
导航栏

OpenAI GPT 3.5 Turbo 模型 「默认」

让 AI 生成你的 git commit 提交信息简短描述

demo-gif

快速体验

利用 npx 填入 Token ,并在你的任何项目中运行下列命令进行体验
OpenAI API Token 获取: https://platform.openai.com/account/api-keys

sh
CZ_OPENAI_TOKEN="sk-xxxxx" npx czg ai
CZ_OPENAI_TOKEN="sk-xxxxx" npx czg ai
sh
CZ_OPENAI_TOKEN="sk-xxxxx" bunx czg ai
CZ_OPENAI_TOKEN="sk-xxxxx" bunx czg ai

配置 OpenAI token

  1. https://platform.openai.com/account/api-keys
    登陆并创建你的 OpenAI API 密钥,通常以 sk- 开头
  2. 运行命令 npx czg --openai-token=<API secret key> 填入 OpenAI API 密钥完成设置
sh
npx czg --openai-token=sk-xxxxx
# 如果你在需要进行 socks5 或 http proxy 代理请求,可以添加选项 `--api-proxy` 进行代理配置
# npx czg --openai-token=sk-xxxxx --api-proxy="http://127.0.0.1:1080"
npx czg --openai-token=sk-xxxxx
# 如果你在需要进行 socks5 或 http proxy 代理请求,可以添加选项 `--api-proxy` 进行代理配置
# npx czg --openai-token=sk-xxxxx --api-proxy="http://127.0.0.1:1080"
sh
bunx czg --openai-token=sk-xxxxx
# 如果你在需要进行 socks5 或 http proxy 代理请求,可以添加选项 `--api-proxy` 进行代理配置
# bunx czg --openai-token=sk-xxxxx --api-proxy="http://127.0.0.1:1080"
bunx czg --openai-token=sk-xxxxx
# 如果你在需要进行 socks5 或 http proxy 代理请求,可以添加选项 `--api-proxy` 进行代理配置
# bunx czg --openai-token=sk-xxxxx --api-proxy="http://127.0.0.1:1080"
sh
czg --openai-token=sk-xxxxx
# 如果你在需要进行 socks5 或 http proxy 代理请求,可以添加选项 `--api-proxy` 进行代理配置
# czg --openai-token=sk-xxxxx --api-proxy="http://127.0.0.1:1080"
czg --openai-token=sk-xxxxx
# 如果你在需要进行 socks5 或 http proxy 代理请求,可以添加选项 `--api-proxy` 进行代理配置
# czg --openai-token=sk-xxxxx --api-proxy="http://127.0.0.1:1080"

全局使用

sh
npm install -g czg
npm install -g czg
sh
brew install czg
brew install czg
sh
# 设置token `czg --openai-token=sk-xxxxx`
# 设置完token后,在你的任何项目中,运行下列命令
czg ai
# 返回多个简短描述,并开启选择模式
git czg ai -N=5
# 设置token `czg --openai-token=sk-xxxxx`
# 设置完token后,在你的任何项目中,运行下列命令
czg ai
# 返回多个简短描述,并开启选择模式
git czg ai -N=5

作为项目依赖使用

sh
npm install -D czg
npm install -D czg
sh
yarn add -D czg
yarn add -D czg
sh
pnpm install -D czg
pnpm install -D czg
  1. package.json 中添加 script
  2. 在设置完 token 后运行启动命令 npm cz ai | yarn cz ai | pnpm cz ai
json
{
  "scripts": {
    "cz": "czg"
  }
}
{
  "scripts": {
    "cz": "czg"
  }
}

npx 使用

  • 在设置完 token 后,运行命令在你的任何项目中
sh
npx czg ai
npx czg ai
sh
bunx czg ai
bunx czg ai

返回多个简短描述,并开启选择模式

sh
npx czg ai -N=5
npx czg ai -N=5
sh
bunx czg ai -N=5
bunx czg ai -N=5

配置

  • 国内用户如果无法访问 OpenAI API 可进行 proxy 代理设置后进行使用

    亦或是使用 --api-proxy 进行代理配置

  • 如果你开启了配置 useAI,但是本次你不想使用 AI 模式,想切换为普通模式,可以运行命令

    • czg CLI: czg --no-ai
    • Commitizen CLI + cz-git: no_czai=1 cz
  • 如果你想自定义配置发起 OpenAI 请求的描述信息,像支持本地化,可以使用配置项进行更改 aiQuestionCB,例如:

js
module.exports = {
  aiQuestionCB: ({ maxSubjectLength, diff }) => `用完整句子为以下 Git diff 代码写一个有见解并简洁的 Git 中文提交消息,不加任何前缀,并且内容不能超过 ${maxSubjectLength} 个字符: \`\`\`diff\n${diff}\n\`\`\``,
}
module.exports = {
  aiQuestionCB: ({ maxSubjectLength, diff }) => `用完整句子为以下 Git diff 代码写一个有见解并简洁的 Git 中文提交消息,不加任何前缀,并且内容不能超过 ${maxSubjectLength} 个字符: \`\`\`diff\n${diff}\n\`\`\``,
}

如何实现

  • 运行 git diff 命令获取文件的差异,并结合描述信息,发送请求给 OpenAI GPT 3.5 Turbo API,来获取 AI 生成的简短描述
  • 💡 灵感来源 aicommits 并修改了部分代码

我只是尽力将工具做得更好,如果可以的话欢迎给一个star ⭐