1. 引言
GitHub Copilot 是由 GitHub 推出的一款 AI编程助手 ,基于大量 公开源代码训练 的 深度学习模型,旨在帮助开发者更快、更智能地编写代码,于2022年6月22日正式上线。
💁♂️ 所以,不是什么新东西了,深度使用了 Github Copilot + GPT4 好一阵子,感觉自己成了一个
不会写代码,只会 问问题 & 按Tab键位的废物开发🤡
以前折腾过一些 提高开发效率 的伎俩,用于 自动生成代码:
- 《🤡花3分钟,重拾开发效率神器 → Live Templates》
- 《🐶再花2分钟,试下冷门小工具 → Postfix Completion》
- 《🤖 自定义IDEA插件 → 划词翻译替换(上)》
- 《🤖 自定义IDEA插件 → 划词翻译替换(下)》
但在这些 AI编程助手 面前,真就是个 弟弟 ,这TM才叫 自动生成 啊!除 Github Copilot 外,期间还体验了几个国产平替,如 CodeGeex 、通义灵码 等,最后发现还是 Copilot 好用 😄,它的核心功能:
- 智能代码生成 :根据 当前代码的上下文 或 开发者编辑的注释 进行 推理 并生成相应的代码片段,包括但不限于 函数、变量、类、测试代码、注释以及文档字符串等。它通常能提供 恰当的补全选项 ,在大多数情况下,只需下 按Tab键 即可轻松完成代码编写。
- 代码理解与互动:Copilot会回答你提的问题,在编码过程中提供即时的帮助和指导,包括:代码解释、代码优化建议、代码Debug等。
🤔 对了,注意和微软推出的 Microsoft Copilot 区分开来:
Microsoft Copilot 是微软推出的 AI助手 ,并集成到Windows 11中,面向 更广泛的用户群体。带来的具体功能和优势包括深度的人工智能体验、跨产品的任务完成能力、智能助理对话、日常 AI 同伴的角色、语音或文本交互方式、全系统集成、深入系统集成与操作控制、打造"杀手级"应用的可能性以及提升 PC 体验的新技能。
Tips:😁 本文后续提到的 Copilot 均指 Github Copilot!!!
2. Github Copilot 不是免费的!!!
😬 那么好用的工具,自然是要💰的,采用 按月收费的订阅制 ,也可以选择年付,价格如下(单位: ❗️ 美刀):
- 个人版 : <math xmlns="http://www.w3.org/1998/Math/MathML"> 10 / 月、 10/月、 </math>10/月、100/年
- 商业版:$19/月/用户
- 企业Plus版:$39/月/用户
使用 国外信用卡 或 PayPal 作为支付方式,都没有的话,可以搞个 国外虚拟信用卡 ,网上这类教程很多,需要的自己搜下。GitHub Copilot 提供了 30天的免费试用期,到期后需要付费订阅才能继续使用。
😏 对了,如果你是 经过认证的学生/老师 或 流行开源库的贡献者 是可以免费使用的,具体可以打开 Github Copilot 官网 查看,如果显示的是 Use Github Copilot for free 而非 Start your 30-day free trial,恭喜你可白嫖一年Copilot 啦 🎉
😑 当然,官方订阅价格对于普通开发崽来说,有点小贵,x宝和x鱼上主要有这两种 "平价" 的使用方式:
- 学生包 :不稳定,存在 封号风险 !建议 开个小号,不要拿自己的主账号来冒险!有时还需要复验学生身份。
- 远程授权 :认准企业授权!有些无良商家使用基于30天免费使用授权,进行低价销售,极其不稳定。
😐 最后,还有 老板可能跑路的风险,所以买的话尽量月付的,万一真润了,损失可以少一点~
3. Github Copilot 安装
😄 假定读者已经解决了费用问题,接着说下如何在两个主流IDE上用上 Github Copilot~
3.1. VS Code
点击左侧 Extensions(扩展) ,搜索 Github Copilot,把这两个插件都装上。
data:image/s3,"s3://crabby-images/91d05/91d054d22597a25a720b3d62a5fb0aafc6ef907d" alt=""
Github Copilot 需要科学上网,得配下代理,点击 Settings ,搜索 proxy,填下代理地址,笔者用的Clash,默认7890端口,设置完 Ctrl+S保存下:
data:image/s3,"s3://crabby-images/c67e3/c67e31723ca4bde76d36face2630e9ad6225c4c8" alt=""
接着需要 Github账号授权登录 ,点下右下角的Copilot图标,会弹出授权,跟着提示走一遍就好了。授权成功 后,小图标上的斜线会没了,点击后顶部会出现这样的弹窗:
data:image/s3,"s3://crabby-images/ec28e/ec28e3b018e9b7cec80d5a353b4997f1eb353738" alt=""
3.2. JetBrains IDEs
依次点击顶部 File → Settings → Plugins → Marketplace → 搜索 Github Copilot ,点击 Install 安装:
data:image/s3,"s3://crabby-images/efad5/efad55a14fd841d2c79d756993c69e5be9e84171" alt=""
同样需要设置下代理,Settings这里搜 proxy ,定位到 HTTP Proxy 选项,在对应位置填写代理地址:
data:image/s3,"s3://crabby-images/21265/21265f155f9827b77152d2de11ed75afc45c9022" alt=""
接着点右下角小图标,点击 Login to Github:
data:image/s3,"s3://crabby-images/02d51/02d5197cc8581934995b2b3059eb347c0fc3f9f1" alt=""
同样是弹窗,跟着提示走一波,授权成功,会出现这样的提示~
data:image/s3,"s3://crabby-images/f095c/f095c9d8d018b0ebf1ccb6da2f57306d1aede24c" alt=""
4. Github Copilot 使用
💁♂️ 下面是笔者的使用经验总结,想看更详细/最新的教程可移步至《GitHub Copilot 官方文档》进行学习~
4.1. 常用快捷键
- Tab → 接受建议。
- Esc → 拒绝建议。
- Alt + ] → 下一条建议 (有多条时才能切换)。
- Alt + [ → 上一条建议。
Alt + \
→ 触发建议 (Copilot没给出建议或不小心拒绝了)。- Ctrl + Enter → 单独打开一个Copilot面板,提供10条建议。
- Ctrl + Shift + C → 打开Github Copilot Chat
😐 默认快捷键可能存在冲突,比如:在我的PyCharm中,Ctrl + \ 是 展开File选项卡。点击 Edit Keyboard Shortcuts... 自定义下快捷键:
data:image/s3,"s3://crabby-images/c1efe/c1efeec50f15500bfbd0217c831d7b99aee17339" alt=""
搜索框输入 Copilot 进行过滤,定位到要修改的选项,双击,点击 Add Keyboard Shortcut 添加快捷键:
data:image/s3,"s3://crabby-images/62042/62042805946fecc8c669a3b466e35278e74de051" alt=""
然后,可以看到冲突项:
data:image/s3,"s3://crabby-images/e2340/e23407a37f503c1a4d31f3e1f1f7d70f24dccca4" alt=""
试了好几个,发现 Alt+. 没被占用,就用这个 触发建议 啦,点击 OK 进行保存。
data:image/s3,"s3://crabby-images/691b6/691b6f230550b7fb553c216808e5d670b6b40cfa" alt=""
VS Code的修改快捷键的方式类似~
4.2. 智能代码生成
😑 感觉核心就这两点:
- 回车/代码变动 后 被动 等 Copilot 给出 补全建议 ,Tab接收建议 或 Esc拒绝建议。
- 注释 里写 prompt (提示词) ,阐述 生成目标内容的逻辑与步骤,Copilot生成对应内容。
前者无🧠Tab,后者只要 prompt玩得溜,可以玩出🌸,简单演示下~
① 描述生成的函数需求
data:image/s3,"s3://crabby-images/29ad8/29ad865bf2aab48e321428f8655ff5a2cc70f7a0" alt=""
② 测试函数
data:image/s3,"s3://crabby-images/8e1e5/8e1e50510d695e8fdb26bc33015a917c48a4a7ff" alt=""
③ 写注释
data:image/s3,"s3://crabby-images/a330a/a330a1f64f5b71c2c0b1a4371cc5b6f903a6008b" alt=""
😂 这里缩减了Gif的帧数,实际上没有那么丝滑,回车完还是得等一下Copilot提示的~
④ 让要求更加详细具体,比如指定函数名,参数命,注释的语言等:
data:image/s3,"s3://crabby-images/79ae3/79ae3c89b2b84e20cacef29945ac55b42c049e71" alt=""
回车换行后,并不会触发提示建议,需要 Ctrl + Enter → 单独打开Copilot面板:
data:image/s3,"s3://crabby-images/255f6/255f6053240a19ae9dc9bf39e19ba5d9634a2d94" alt=""
点击 Refresh ,等待Copilot生成10条建议,挑选喜欢的提示,点击 Accept solution 接受建议,也可以按需复制粘贴合适的内容:
data:image/s3,"s3://crabby-images/2ffb4/2ffb4a68356b981bb4ab750971e975d0f1c1d189" alt=""
🤏综上,生成怎么样的内容,取决于你的提示词怎么写,你可以拿Copilot来 翻译:
data:image/s3,"s3://crabby-images/a4cdc/a4cdc642a22d159717e812f44aabf9e8a70a8647" alt=""
你问我答:
data:image/s3,"s3://crabby-images/df7c2/df7c2315f4d59258ef6cc9735f4b95016c5b5148" alt=""
😂 甚至是 辅助文档编写,比如编写 README.md 文件:
data:image/s3,"s3://crabby-images/9627c/9627c250dd2a415db3fdc70cfa5facaed0c5acca" alt=""
不过markdown默认是没开启建议的,点击 Edit Setting ,找到 markdown,把value从false改为true就可以了。
data:image/s3,"s3://crabby-images/a6262/a6262203719825c0e68d30d19b3446c1372b0452" alt=""
4.3. 代码理解与互动
😳 两款IDE上的 Github Copilot Chat 功能有些许不同。命令 是为了在使用Copilot Chat时提供更专业或针对性的帮助与交互。非强制,比如,你用 解释下xxx 代替 /explain 也是可以的!
4.3.1. JetBrains IDEs
data:image/s3,"s3://crabby-images/e92b0/e92b08fdbe665d43708b4258812bfa9dd7b32c96" alt=""
😄 可以把它当成 简化版的ChatGPT 来使用,不过它只会回答技术相关的问题:
data:image/s3,"s3://crabby-images/5aa3a/5aa3a06f3dabbdd3dfe3f37c74ed52d94a54a342" alt=""
在聊天框输入 / ,它可以针对你 选中的代码/当前鼠标的位置/当前的文件或项目 进行:
data:image/s3,"s3://crabby-images/071ea/071eaacfc09c6541df508f724021ecbf44bef059" alt=""
比如解释代码,选中解释的代码行,除了在聊天框输入 /explain 外,也可以右键依次点击 Github Copilot → Explain This:
data:image/s3,"s3://crabby-images/f6226/f6226007e5322569db65298d0c4643e08da3e3d1" alt=""
对了,默认使用英文解释,如果需要中文,可以再 /explain 后加个 使用中文:
data:image/s3,"s3://crabby-images/842d9/842d9eee637a4e77580d98334d1e3eec0d8a2b0e" alt=""
生成的代码,除了复制,还可以将代码直接插入到光标处~
data:image/s3,"s3://crabby-images/cdc6e/cdc6eb9765130c0e14deec461ced1a1fd3228c0d" alt=""
4.3.2. VS Code
data:image/s3,"s3://crabby-images/dcd01/dcd017751413d29be2463ea32f6c0f2ccd0fa497" alt=""
点底部Copilot的图标,选中 Github Copilot Chat ,键入 /help,发现命令多了不少:
data:image/s3,"s3://crabby-images/4b264/4b2643b55bc5feb1612f6ec0f466c7289c468417" alt=""
组合命令示例:检查终端报错 → @workspace /explain #terminalLastCommand
生成代码 ,除了支持插入到 光标处 外,还可以插入到 新文件 或 终端 中。
data:image/s3,"s3://crabby-images/35b56/35b56782bd2400bf18fec3023ef7709e970a0e8f" alt=""
另外,VS Code的Copilot插件还支持 行内快捷操作 :Ctrl + I → 在当前光标行唤起一个输入框,用于提问或输入命令:
data:image/s3,"s3://crabby-images/4dba9/4dba9b92d3213afdc6feeb25180b46247ea2b7df" alt=""
如果是全局唤起的话,可以按 Ctrl + Shift + I:
data:image/s3,"s3://crabby-images/cc070/cc0707c676ec2931475a4fdadd71be8aac7bbdaa" alt=""
5. 小结
🤔 感觉Github Copilot目前的基本玩法就这些,有遗漏的、或者什么骚操作欢迎在评论区补充,谢谢🙏~