实测 亚马逊 AI 编程助手 Amazon CodeWhisperer(全网最全)
文章作者:疯狂的驸马
一、CodeWhisperer 简介
CodeWhisperer 是亚⻢逊出品的一款基于机器学习的通用代码生成器,可实时提供代码建议。
在编写代码时,它会自动根据我们现有的代码和注释生成建议。从单行代码建议到完整的函数,它可为我们提供各种大小和范围的个性化建议。
亚马逊云科技开发者社区为开发者们提供全球的开发技术资源。这里有技术文档、开发案例、技术专栏、培训视频、活动与竞赛等。帮助中国开发者对接世界最前沿技术,观点,和项目,并将中国优秀开发者或技术推荐给全球云社区。如果你还没有关注/收藏,看到这里请一定不要匆匆划过,点这里让它成为你的技术宝库!
CodeWhisperer 还可以扫描我们的代码以突出显示和定义安全问题。
data:image/s3,"s3://crabby-images/4aefc/4aefc39ac4cb9975a730cdc7454ab55d0e7be8f4" alt=""
codewhispereropen in new window:亚马逊官方出品
目前仅以插件的形式在VS Codeopen in new window、Jetbrainsopen in new window等 IDE 里面使用,如果想试一试可以用 VS Code,目前无限制免费使用免费,并且对环境要求不高,还轻量 ~
亚马逊在 2022 年 6 月发布了 CodeWhisperer 预览版,现在它支持 Python、Java 和 JavaScript。
data:image/s3,"s3://crabby-images/b3e9e/b3e9eed3e9690052e29dd82969d4fbf180fdfd0a" alt=""
CodeWhisperer 经过数十亿行代码的训练,由机器学习提供支持,旨在实现相同的目标。无论我们是学生、新开发人员,还是经验丰富的专业人士,CodeWhisperer 都有助于我们提高工作效率。
其支持多种 IDE 和语言。要开始使用,我们只需安装合适的 Amazon IDE Toolkit,启用 CodeWhisperer 功能,输入我们的预览访问代码,然后开始键入:
data:image/s3,"s3://crabby-images/76ec6/76ec60c566fc219cdb5f8c4d9ede7bcf03f19572" alt=""
CodeWhisperer 可以持续检查我们的代码和注释,并为我们提供语法正确的推荐。这些推荐根据您的编码风格和变量名称合成,而不仅仅是代码段。
CodeWhisperer 使用多个上下文线索来提供推荐,包括源代码中的光标位置、光标前面的代码、注释以及同一项目中其他文件中的代码。您可以按原样使用推荐,也可以根据需要对其进行改善和自定义。正如我之前所提到的,我们使用从开源存储库、内部 Amazon 存储库、API 文档和论坛中提取的数十亿行代码训练(并将继续训练)CodeWhisperer。
在亚马逊云科技博客的一篇文章中,Mark Richman 解释说,CodeWhisperer 的模型是在“包括 Amazon 开源代码在内的各种数据源”上训练的。有了这个语料库(显然确实存在)完善 CodeWhisperer 的模型,编写从 S3 读取文件的代码应该是一个很好的测试用例。
在使用 CodeWhisperer(CW)时,我们需要写一个注释,描述我们希望函数去做什么。注释的描述性和准确性越高,系统就越能更好地推断出我们想要的逻辑。
Function to open an S3 file
比如注释以 Function 开头,让 CW 知道你想要创建一个函数。也就是说,你需要添加一个注释,作为给 CW 的提示。
CW 分析注释并生成一个函数的定义。此时,你可以在生成函数体之前修改函数定义。CW 还可能提供多种函数定义供你选择。
IntelliJ 集成 CodeWhisperer 的截图:
data:image/s3,"s3://crabby-images/e6843/e6843b8d9e4b0ce92a55e246c90067447dfbf8d5" alt=""
点击“插入代码”,你的函数就在注释的下方创建好了。注意 CodeWhisperer 不仅插入了代码,还创建了一个文档字符串。
看起来不错!这段代码实现了你的注释所期望的功能,并且是在几秒钟内就生成了。
节省了查找 boto3 API 的时间,你只需要检查代码,确保语义正确。
接着看看提出更多要求时,会发生什么。
这有一个很有用的例子:写一个函数从 S3 的文件中返回前“n”行。
真厉害!CodeWhisperer 使用了之前创建的辅助方法 open_s3_file,并生成了正确的函数。
在 CW 生成函数体之前,你可以修改参数名,提高代码的可读性。例如,如果我们输入:
CW 会提示:
在生成函数体之前,我们可以修改函数定义,使其更具描述性:
如果我们接受它的函数定义,CodeWhisperer 将使用函数签名和注释来构建函数体。得到的函数将使用改进后的参数名。
CodeWhisperer 不仅仅可以创建整个函数;它还可以在函数中插入代码片段,并在过程中推断相关变量。
1.1 CodeWhisperer 是一个重要的生产力助推器
使用 CodeWhisperer,我能够更快地编写代码。到目前为止,最大的价值是 S3 示例所演示的功能。
如果我自己写代码,大部分时间将会用来查找 boto API 文档,以确保写出正确的调用。使用 CodeWhisperer,则只需三秒钟。
这让我想到了一段曾花了很多时间的烦人代码:给 CloudWatch 发送数据。让我们看看 CodeWhisperer 能否有所帮助,试试提供注释:“Function to emit a CloudWatch metric”。
非常有用!CW 为我节省了许多打字和查阅 API 文档的时间。
我有可能需要重构这段代码,但即使我从零开始编写它,第一步也要写出类似这样的原始逻辑。如今只花三秒钟,我节省了编写大量样板代码的时间,有了一个很好的自定义或重构的起点。
1.2 CodeWhisperer 的实际应用
我在 PyCharm 中安装了 CodeWhisperer ,并对其进行了测试。以下是一些示例,向您展示了它可以执行的操作。我想构建一个质数列表。我键入 # See if a number is pr。CodeWhisperer 完成此操作,然后我按下 TAB(实际键特定于每个 IDE)接受推荐:
data:image/s3,"s3://crabby-images/d6b04/d6b04369c93602aef85babea97321de9b8857cd0" alt=""
在下一行,我按下 Alt+C(同样是 IDE 特定),然后我可以在一对函数定义之间进行选择。我接受第一个函数,CodeWhisperer 推荐函数体,以下是我所拥有的:
data:image/s3,"s3://crabby-images/f4fe0/f4fe03286c202408b2172b9a251ea6f7131b27f2" alt=""
我编写 for 语句,CodeWhisperer 推荐循环的主体:
data:image/s3,"s3://crabby-images/e07f1/e07f119df872622745f4e81710f218cafd2340a9" alt=""
CodeWhisperer 还可以帮助我编写用于访问各种亚马逊云科技服务的代码。我从 # create S3 bucket 开始,然后按 TAB 键完成剩余部分:
data:image/s3,"s3://crabby-images/a759b/a759bd3a7309831f5e5032346ad2448c7da92029" alt=""
看到这里,大家是不是觉得还不错,接下来教大家如何安装,很简单的~
二、CodeWhisperer 安装教程
2.1 IntelliJ IDEA 安装 CodeWhisperer 插件
在 IDEA 中打开配置窗⼝,选择 Plugins,搜索"Amazon Toolkit",点击 Install,点击 OK 按钮,如下图:
data:image/s3,"s3://crabby-images/9bb6f/9bb6fd68832657fdeed9a77a9ddbc4732fb93311" alt=""
安装完之后重启 IDEA,如下图:
data:image/s3,"s3://crabby-images/6b16f/6b16f1a00a990833550900f5efb2dc9e47d2d4ac" alt=""
打开 Amazon Toolkit 视图(菜单 View/Tool Windows/AWS Toolkit),点击"Developer Tools"tab⻚⾯,选择“CodeWhisperer/Start",如下图:
data:image/s3,"s3://crabby-images/9988f/9988fe719ec8773436d520904dc83ce32194e591" alt=""
data:image/s3,"s3://crabby-images/6fcfe/6fcfeb1d76f94cc1c5ab38cda28c43eac6561009" alt=""
弹出的窗⼝中选择“Use a personal email to sign up and sign in with Amazon Builder ID",点击“Connect”按钮,如下图:
data:image/s3,"s3://crabby-images/9d15e/9d15e7820f451c9b703660f5eee4e08130cbd4ed" alt=""
在弹出的窗⼝中,选择“Open and Copy Code”,如下图:
data:image/s3,"s3://crabby-images/73985/7398593ee0ece4a0d6fdf3f1b99b748253a07f84" alt=""
此时会在浏览器中打开⼀个⻚⾯,按 ctrl-v 粘贴 code 值,点击“Next“,如下图:
data:image/s3,"s3://crabby-images/e6443/e6443195de7889a0107d7c444868fdfe7771dfd3" alt=""
输⼊邮箱地址,点击"Next",如下图:
data:image/s3,"s3://crabby-images/78b06/78b06cfc93df386dc961cfaae70fd2a7b651b36b" alt=""
输⼊名字,点击“Next”,CodeWhisperer 会向邮箱中发送⼀个验证码,如下图:
data:image/s3,"s3://crabby-images/7891c/7891c19ab1eec2f4803843371ef2388c495eba30" alt=""
打开邮箱,可以看到验证码,如下图:
data:image/s3,"s3://crabby-images/06a08/06a0812ac829b80d9387de50c4a35150557741af" alt=""
复制验证码,粘贴到输入框,点击“Verify”按钮,如下图:
data:image/s3,"s3://crabby-images/fd7a3/fd7a377ccdea9ef97617959ad27f48b2dee3fa2d" alt=""
设置密码,点击“Create AWS Builder ID“,如下图:
data:image/s3,"s3://crabby-images/f03e7/f03e7e4e4864a65fd87a3b573324a32ac616febc" alt=""
在最后⼀个⻚⾯中点击“Allow”按钮,如下图:
data:image/s3,"s3://crabby-images/50cea/50cea7bf4bb94b55d73edffec9c54339422fe627" alt=""
出现如下提示后,即表示注册 Amazon builder ID 成功,如下图:
data:image/s3,"s3://crabby-images/d089a/d089abbd4564efab75bf94ab3331713f6c924327" alt=""
返回 IDEA,在 Amazon Toolkit 视图中的 Developer Tools 中可以打开或关闭代码⽣成功能,如下图:
data:image/s3,"s3://crabby-images/add6e/add6eab5fee9a54463bcbfe04a90acafbdc540dc" alt=""
此时,就可以愉快的使用 AI 编程了。
2.2 VSCode 安装 CodeWhisperer 插件
安装 Amazon Toolkit 插件,具体到 VS Code 侧边栏搜索并安装
data:image/s3,"s3://crabby-images/c645a/c645a7b9650130062b133d97627162dc6ab5bb5e" alt=""
侧边栏点击 aws,>> DEVELIOPER TOOL >> CodeWhisper >> Start
data:image/s3,"s3://crabby-images/d209e/d209e8359cb6311431ae49429a2774a891fb9cdb" alt=""
在下拉菜单中点击 Use a personal email to sign up and sign in with Amazon Builder ID
data:image/s3,"s3://crabby-images/e38b9/e38b99fa52f209b3ab172f3b06c009aeb799b6ea" alt=""
点击 Copy Code and Proceed,这将自动复制代码
data:image/s3,"s3://crabby-images/22dbf/22dbfdc751b50a7b1aeab3e80f442546fc200273" alt=""
一般会提示外部网站打开提醒,选择打开
data:image/s3,"s3://crabby-images/dd303/dd3034a815912f5dcfd5921cc9df364583457d5d" alt=""
5.打开网站后,输入点击 Copy Code and Proceed 时得到的代码,点击 Next
data:image/s3,"s3://crabby-images/19ce3/19ce3f1194d4a4be063b65ccea80b14f19450108" alt=""
6.输入自己的邮箱地址(同时登录你的邮箱等待验证码),点击 Next
data:image/s3,"s3://crabby-images/a85c7/a85c73e1dcdc657374c5b5f9ef80c78e4fc630a0" alt=""
7.重复之前步骤,但是由于已经在浏览器上登录成功了,所以步骤非常简单 粘贴代码后将会提示以下内容,点击 Allow 即可
data:image/s3,"s3://crabby-images/91aeb/91aeb379718cb2784caa463386374a9af5610581" alt=""
data:image/s3,"s3://crabby-images/1c028/1c028217e5dda7173b159384770e5a3a6718f8d3" alt=""
data:image/s3,"s3://crabby-images/97ae9/97ae993a7384c08f48c8eb1df10c01276e946e15" alt=""
等左下角的亚马逊云科技扩展颜色正常,对勾状态,说明连接成功
data:image/s3,"s3://crabby-images/8bacb/8bacba4245671e8ce0cf81a1655f3d80ef452977" alt=""
此时,就可以愉快的使用 AI 编程了。
2.3 PyCharm 安装 CodeWhisperer
1.打开 Pycharm 插件管理
在 JetBrains IDE 中,导航到设置菜单(在 macOS 上为⌘ + ,在 Windows 上为文件→设置),然后单击左侧菜单上的“插件”。
在菜单顶部,单击 Marketplace 并在搜索栏中键入 “Amazon Tookit”。然后点击安装。
data:image/s3,"s3://crabby-images/71185/7118537fc534409c18e586bfc887eb5007eabb9d" alt=""
2.安装完成后重启 IDE
data:image/s3,"s3://crabby-images/10e97/10e97b42f6e2d0f88345b87eddf8a09fb991e035" alt=""
3.将 Pycharm 连接到亚马逊云科技(Amazon Build ID 创建),重复之前步骤
IDE 重新启动后,您将看到一个新的 Amazon Toolkit 工具窗口。还可以通过 View -> Tool Windows -> Amazon Toolkit(视图 -< 工具窗口 -< Amazon Explorer)访问此窗口。
然后点击"Developer Tools"标签,选择“CodeWhisperer/Start"
data:image/s3,"s3://crabby-images/d5148/d5148d6259cd81249a2d924c00205ed96c91b9ac" alt=""
此时,就可以愉快的在 PyCharm 里使用 AI 编程了。
2.4 快捷键使用方法
全程需要按快捷键调用 Codewhisperer,主要的几个用法如下:
data:image/s3,"s3://crabby-images/135fb/135fb4597448858e66295e394aac893ab647959c" alt=""
三、简单自动编码演示
回到 IDEA,看到如下界面,即表示注册并启动成功:
data:image/s3,"s3://crabby-images/98517/985172d8e02f723f963ecf076e4466befa809dd6" alt=""
下面我们新建任意 Java 文件,看看他如何能够帮助我们自动生成代码。
3.1 单行代码自动补全
输入字符串 public。根据输入,CodeWhisperer 生成了建议列表
data:image/s3,"s3://crabby-images/42a19/42a19bcde851c274e130cf8702a0f09f73fac1dd" alt=""
3.2 CodeWhisperer 生成完整代码
CodeWhisperer 可以根据编写的注释生成完整的函数。
data:image/s3,"s3://crabby-images/1ccc5/1ccc54485786ed435b872543370414149c1f632d" alt=""
data:image/s3,"s3://crabby-images/0ce29/0ce29877107db0f9150d263a40eca33051241676" alt=""
类似于 if/for/while 等代码块的生成。
data:image/s3,"s3://crabby-images/d6ee5/d6ee5cd6a1f9a0f5e398cb694464c9ebc5b9846d" alt=""
大家如果看到这有疑问,可以接着看第四部分,有详细的测试说明。
3.3 其根据签名自动生成代码
data:image/s3,"s3://crabby-images/6d510/6d510b4f4401a9e4f19a8209cd9ef92da72a339b" alt=""
看到这里,大家应该有个简单的了解了,咱们接着往下看~
四、AI 编程代码实测及项目体验
4.1 简单函数代码测试
首先,我先用中文注释了“写一个读取 csv 文件的函数” 回车后可以看到 CodeWhisperer 自动显示出来
data:image/s3,"s3://crabby-images/51514/5151427c0afec6d6365db47308ba8be81016e95c" alt=""
按快捷键 Tab 确认键入后,接着回车后 CodeWhisperer 又自动生成了以下代码:
data:image/s3,"s3://crabby-images/4a794/4a7947ad9b31694550f9c497f8e94d10e5e36ff9" alt=""
感觉这个 CodeWhisperer 自动生成的代码还不错,我选择了 Insert Code 键入使用。
紧接着用中文又注释了“创建一个简单的爬虫简单函数”
data:image/s3,"s3://crabby-images/07444/07444e2c669d9019403be16ad8aa13cee86c04a6" alt=""
在这选择了第三个自动代码,同样 Tab 键入。
接下来是注释“冒泡排序”后回车
data:image/s3,"s3://crabby-images/925d4/925d4668c8741bd8861aba656e62023a0fb52d34" alt=""
注释“选择排序”后回车
data:image/s3,"s3://crabby-images/5a77b/5a77b7f574c52f3d38d9dc841b7cbbf693a71728" alt=""
中文注释实测完后又对英文注释进行了测试,如下图所示:
data:image/s3,"s3://crabby-images/da49e/da49e84f4f142cf16fdee4c7c99271906f323402" alt=""
乘胜追击,又对创建和上传文件代码进行自动生成测试,同样得到了预期的效果。
data:image/s3,"s3://crabby-images/39a0b/39a0bed2c94a9e87fb4f1a6d1be18f3ecd664b4c" alt=""
对于简单的函数实测让我感觉这个工具还挺不错的,因为可以根据自己想要的注释自动生成多个代码建议,这样不仅节省了大量的编码时间,而且多种代码建议可供选择,一定程度上提升了自己编写代码的质量。
4.2 代码安全扫描实测
接下来用 CodeWhisperer 去扫描我们代码中的安全漏洞,以下是运行按钮的位置
data:image/s3,"s3://crabby-images/29835/2983562d805ed914bfb4b9bfe293a020c8126f24" alt=""
打开我想扫描的文件,然后运行安全扫描
data:image/s3,"s3://crabby-images/d374e/d374e58ad1979d81b42f0f48a596e5d3352aa9d8" alt=""
结果发现 CodeWhisperer 探测到该文件中有两个安全问题。 通过查看问题栏,点击事件定位到代码中,我们将鼠标移入到突出显示的代码,查看建议的措施,如下所示,问题指出在该例子中未加密的亚马逊云科技凭证被记录下来,是一个安全漏洞,它建议我们重写代码并且修复该漏洞。
data:image/s3,"s3://crabby-images/0b41a/0b41a686d1c5f6a706beb406a29e02f65e057499" alt=""
同样查看第二个问题,CodeWhisperer 告诉我们讲应该把标识设置为 True。
data:image/s3,"s3://crabby-images/0b8e1/0b8e144609eead227e0de603c0d38aeeebbb4593" alt=""
根据 CodeWhisperer 的建议,我进行了对应修改,两处安全问题修改如下:
data:image/s3,"s3://crabby-images/03cf3/03cf3971c47949676485ab269d92dec60cda8b17" alt=""
data:image/s3,"s3://crabby-images/7063a/7063abec842c67311a0616003211b99c05f2e434" alt=""
修改后重新扫描了文件,扫描完成,显示没找到问题。
data:image/s3,"s3://crabby-images/3ca2d/3ca2d21858e93b1663253634e23e554c89c54a6d" alt=""
对于安全扫描这项功能,我还是挺惊艳的,没想到能实测找出问题并给出对应的解决问题,因为这一点我对 CodeWhisperer 的好感又增加了。
4.3 代码引用跟踪功能实测
在这里想实现一个函数来创建一个 dynamo DB 表。 如下图所示进行了实际测试 “implement a function to create a dynamoDB table”
data:image/s3,"s3://crabby-images/af524/af5240061e06b17adc2fffb0205bc80f4882c64d" alt=""
以下是 CodeWhisperer Reference Log 给出的建议:
data:image/s3,"s3://crabby-images/b34a3/b34a39b6f46ac2f29f4af4c0e576abbe0c2284b7" alt=""
根据代码建议标注被文件跟踪器标记为 MIT 许可证,其引用了 Apache-2.0 许可证下的代码。我选择接受了这些标记代码,然后发现 CodeWhisperer 自动记录了引用我需要的许可证信息,这样我就可以在我的代码上添加适当的许可证和归属信息。 这个功能实测完感觉也挺有用的,对代码涉及到的许可证和归属信息问题进行了有效解决。
4.4 计算机视觉工程项目实测
在对官网显示的几项功能测试完后,又在平时用到的实际项目上进行了测试,我选取了常用的一些 CV 检测模型,以下是 ShuffleNet 的实际测试效果。
首先,我在实例化训练数据集上,对缺失的代码段进行测试,看 CodeWhisperer 是否能联系上下文进行代码补全。
data:image/s3,"s3://crabby-images/57fcf/57fcf11c71234198ae544452d8a8c5174f9a0bec" alt=""
进行回车操作后,CodeWhisperer 显现出来了所给的建议。
data:image/s3,"s3://crabby-images/47b6d/47b6df181475849ef982e7f887d87b99241c60a6" alt=""
目前看所给的建议正确,接着我又对冻结权重部分进行了测试,
data:image/s3,"s3://crabby-images/61723/6172340275132e8ce36f21c805a829786037257f" alt=""
这回我又利用了 CodeWhisperer 的快捷键 ALT+C 进行了测试,
data:image/s3,"s3://crabby-images/faa64/faa644e5e64a4acf80c71f4c5c6d283a0d35d025" alt=""
结果显示自动生成了 False 选项,测试到这里真的让我觉得这个工具是真的好,可以帮助我解决代码中遇到的很多问题。 在训练代码中测试完,我又接着对检测模型代码进行了测试,如下图所示在 transform 指向中为我建议了 img。
data:image/s3,"s3://crabby-images/23027/230272bc91c170d0761377fb9dfb0066de96b9db" alt=""
最后,我对检测模型代码进行了运行测试,正确的检测出图片为蒲公英 dandelion。
data:image/s3,"s3://crabby-images/ae758/ae758e63f37dec44e459d736794f2832d2d32842" alt=""
总的来说,CodeWhisperer 辅助我完成了 CV 模型的代码编写和模型检测,达到了官网所展示的预期。接下来,我要让 CodeWhisperer 帮助我完成更复杂的任务了,哈哈
五、Amazon CodeWhisperer 实测体验总结
5.1 CodeWhisperer 可以帮助我成为一个更好的开发者吗?
通过以上的测试,我觉得它可以帮助我成为一个更好的开发者。
首先,它可以为我节省大量的时间和精力,让我能够专注于改进、重构和测试。
其次,它通过承担一些同质化的繁重工作,让我有机会成为一个更好的程序开发人员。
比如上面的测试的例子是 Amazon 工具(经过 Amazon 开源代码训练)能够表现出色的例子。
当然,在大多数开发人员需要花费很多时间的地方,比如编写领域相关的逻辑时,我又多测试了一下,让我们看看 CodeWhisperer 会不会也有帮助。
比如从 Python 文档中的数据类示例开始。
data:image/s3,"s3://crabby-images/d4951/d4951b03cb983fd3a67e18defb09017ace948ad8" alt=""
其实我想知道 CodeWhisperer 是否可以向这个类添加一个方法。让我们看看如果添加注释:" Function that return this item costs more than $10",会发生什么?
data:image/s3,"s3://crabby-images/8ab7e/8ab7e2d52a8137455d5a4f3cb09e2c95d475a6a5" alt=""
结果是非常酷的。值得注意的是,CodeWhisperer 给函数起了一个直观的名字,并包含了对 self 的引用。
接着,让我们尝试用 CodeWhisperer 来做测试,看是否会触及它的极限。
data:image/s3,"s3://crabby-images/4ef40/4ef407bfb606c8c0f490ff7b9896852acb5d95b2" alt=""
在上面的代码中,我输入了注释,CW 自动完成了剩下的工作。 测试似乎是一个极好的证明 CW 可以节省时间的例子。我不需要浪费时间去想测试的值,也不用输入所有的成员变量和方法。
总的来说,可以帮助我成为一个更好的开发者,但是任何辅助工具都有利有弊,CodeWhisperer 也是才发布不久,通过测试我也想邀请大家去进行实际测试,可以对使用 CodeWhisperer 遇到的问题大家一起相互讨论,一起促进这个编程助手迭代和完善~
评论