我做了一个 VSCode 插件版的 ChatGPT

大家好,我是风筝

其实很早之前就想学学 VSCode 插件开发了,但是又不知道做什么,加上我这半吊子前端水平,迟迟没有动手。

最近 ChatGPT 火的一塌糊涂,我也一直在用,真的非常好用,有些问题之前需要 Google 搜索,现在用 ChatGPT 基本上都能直接解决,效率提升了不少。

但是吧,浏览器和 IDE 来回切换又很麻烦,所以我灵机一动,那就开发个 ChatGPT 插件吧,即可以学习学习 VSCode 插件开发,又可以做一个方便的效率工具,岂不是一举两得,美哉美哉。

于是我就动手写了下面这个插件,叫做 mini ChatGPT,现在已经发布到 VSCode 插件市场了。

有条件的同学可以安装一下,试试效果如何。

插件功能特点

  • 界面简洁,没有多余的干扰;
  • 像 ChatGPT 官网输出效果一致,打字效果实时输出;
  • 支持两轮上下文(太多了浪费 tokens),大致等于支持上下文;
  • 代码美化+格式化,并且可以一键复制,直接粘贴到 vscode 中;

我做了一个 VSCode 插件版的 ChatGPT

插件安装

当然了,这是需要正确的上网姿势。

你可以直接在 VSCode 的商店直接搜索 mini ChatGPT安装。

我做了一个 VSCode 插件版的 ChatGPT

也可以到应用市场上安装。

我做了一个 VSCode 插件版的 ChatGPT

插件地址:https://marketplace.visualstudio.com/items?itemName=fengzheng.code-chatgpt-assistant

插件使用

  1. 点击查看->命令面板,或者使用快捷键(MacOS: Shift + Command + P,Windows:Shift + Control + P
  2. 输入 Chat 并回车。
    我做了一个 VSCode 插件版的 ChatGPT
  3. 如果是首次使用,会弹出提示输入框,在此输入 ChatGPT 的 API。使用的就是原滋原味的 ChatGPT API 接口,官网上都写的很清楚,所以需要使用插件的小伙伴提供自己账号的 API key。下面有介绍如何获取ChatGPT API key。
    我做了一个 VSCode 插件版的 ChatGPT
  4. 之后就可以使用啦
    我做了一个 VSCode 插件版的 ChatGPT
  5. 如果之后想更换 ChatGPT 的 API key,在命令面板中输入 ChatGPT API 即可。

使用建议

此插件只有一个 webview 实现,打开之后独占一个 tab,可以设置向左或向右拆分,然后在左侧使用此插件向 ChatGPT 提问,右侧是代码文件,这样就不用来回切换了,而且可以将代码片段一键复制,然后直接运行。

我做了一个 VSCode 插件版的 ChatGPT

获取 ChatGPT API key

  1. 先准备好正确的上网工具,不要用亚洲节点。

  2. 之后到 OpenAI 官网注册账号。

  3. 个人中心 创建一个 API key。

我做了一个 VSCode 插件版的 ChatGPT

开发历程

作为一个后端开发,我的前端水平是非常一般的,所以代码中有瑕疵的地方还请见谅。对了,代码已经放到 GitHub 上了。

仓库地址:https://github.com/huzhicheng/vscode-ChatGPT

VSCode 插件开发,官方建议是用 TypeScript 开发,所以项目完全采用了 TS 开发。由于功能比较简单,没有那么多复杂的设置,由于边学边做,太复杂的也没考虑。整个插件的核心其实就是一个 webview,在webview中实现界面布局和样式,难点就在于webview与插件本身来回的数据传递,但也都是常规用法。

整个写代码的过程其实也就几个小时,当然过程中的遇到的一些问题我都是跟 ChatGPT 提问的,包括样式都是直接描述需求,ChatGPT 给我一个大致的框架,我再微调一下就可以了。

所以这样看下来,其实是我和 ChatGPT 合作开发的。

后来发布到应用商店,写 readme 介绍和使用说明花了一些时间。

问题和建议

目前的版本功能比较简单,没有 ChatGPT 官方的聊天记录列表功能,如果真的有人用的话,后期考虑加上。

由于ChatGPT 官方并未提供上下文的 API 支持,所以只能采用其他方式模仿上下文能力,目前的做法是记录前两轮提问和回答,然后在下次提问的时候,将前两轮的提问和回答告诉 ChatGPT ,并且明确告诉 ChatGPT,例如下面这样。

第一轮问题:你好。

第一轮回答:你好,请问有什么要帮忙的吗?

第二论问题:请帮我写一段 Python 爬虫抓取知乎回答的 demo。

第二轮回答:好的,下面是一段抓取知乎回答的 Python 示例。....省略多行代码。

第三轮问题:帮我改成 Java 的。

这时候,我会将实际的 prompt 改成下面这样的。

下面中括号部分是前两轮的问题和回答,只用作参考。[my question is:"你好",your anwser is:"你好,请问有什么要帮忙的吗?".my question is:"请帮我写一段 Python 爬虫抓取知乎回答的 demo。",your anwser is:"好的,下面是一段抓取知乎回答的 Python 示例。....省略多行代码。".]

下面引号包含的这部分是真正的问题:"帮我改成 Java 的。"

采用这种方式,几乎可以模拟上下文的操作,但是偶尔会出现错乱,这块儿还有优化空间,还会继续优化。

如果各位小伙伴使用过程中发现什么问题,或者有什么更好的建议,都可以加我好友直接跟我说。

欢迎捧场,赶紧用一用吧,觉得好用的话,可以推荐给身边的小伙伴也用一下。

我做了一个 VSCode 插件版的 ChatGPT

原文链接:https://www.cnblogs.com/fengzheng/p/17389879.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:我做了一个 VSCode 插件版的 ChatGPT - Python技术站

(0)
上一篇 2023年5月11日
下一篇 2023年5月11日

相关文章

  • 重试,让程序更健壮

    任何通过网络与其它应用通讯地的程序,都应该有足够的灵活性,来应对短暂的临时性故障。因为这些故障很多时候是可以自恢复的。 例如,为了避免服务过载,很多应用会采取某些限流措施,在并发请求达到一定数量时,暂时性的拒绝新的请求加入。这种情况下,尝试使用该应用的程序,一开始可能会被拒绝连接,但下一刻就好了。 因此,在设计系统时,应该考虑到此种故障。并且在条件允许时,加…

    JavaScript 2023年4月17日
    00
  • Dom 结点创建 基础知识

    DOM(Document Object Model)是一种用来访问和操作 HTML 或 XML 文档的标准 API。在 JavaScript 中,通过 DOM API 可以在文档中创建新的节点,也可以对现有的节点进行操作。 创建 DOM 结点 在页面中创建 DOM 节点有两种方式:通过 HTML 代码创建,或者通过 JavaScript 代码动态创建。 通过…

    JavaScript 2023年6月10日
    00
  • 手写TypeScript 时很多人常犯的几个错误

    当我们手写TypeScript时,很容易会犯一些常见的错误。在这里,我来分享一些常见的错误,并提供一些示例说明和解决方案。 1. 类型声明不正确 在TypeScript中,类型声明非常重要,而类型声明不正确则会导致代码中的错误。例如: function add(num1, num2) { return num1 + num2; } let result = …

    JavaScript 2023年6月10日
    00
  • 浅谈js中StringBuffer类的实现方法及使用

    浅谈JavaScript中StringBuffer类的实现方法及使用 1. 简介 StringBuffer 是一种可变字符串,它是 Java 中常用的类之一,用于动态生成字符串。而在 JavaScript 中,由于字符串是不可变的,因此开发者们开发了一个类似于 StringBuffer 的类,以方便字符串的拼接。 在 JavaScript 中,StringB…

    JavaScript 2023年5月28日
    00
  • AngularJS实现的base64编码与解码功能示例

    AngularJS是一个流行的JavaScript框架,支持对前端数据进行处理和操作。Base64编码是一种将二进制数据转换成ASCII字符串的编码方式,它经常在各种场景中使用,比如网络传输、图片上传和加密等等。在AngularJS中实现Base64编码与解码功能非常简单,下面我将为大家详细介绍如何实现。 一、安装AngularJS 首先我们需要在项目中引入…

    JavaScript 2023年5月19日
    00
  • [js高手之路]HTML标签解释成DOM节点的实现方法

    以下是关于“[js高手之路]HTML标签解释成DOM节点的实现方法”的完整攻略: 1. HTML标签解释成DOM节点 在解释HTML标签时,我们需要将HTML标签转换为DOM节点,并根据不同的属性来设置节点的属性。一个比较简单的实现方法是使用正则表达式来匹配标签,并进行解析。 以下是一个简单的示例代码,通过正则表达式解析HTML标签并生成相应的DOM节点: …

    JavaScript 2023年6月10日
    00
  • 一文彻底搞懂Vue的MVVM响应式原理

    一文彻底搞懂Vue的MVVM响应式原理 了解Vue.js Vue.js 是一个渐进式JavaScript框架,它采用 MVVM(Model-View-ViewModel)模式进行构建。其中 ViewModel 是 Vue.js 主要的核心,Vue.js 的响应式也是建立在 ViewModel 上的。 Vue.js 的响应式原理 Vue.js 的响应式原理是基…

    JavaScript 2023年6月10日
    00
  • 如何在JavaScript中谨慎使用代码注释

    如何在JavaScript中谨慎使用代码注释 为什么需要谨慎使用代码注释 代码注释是一种注释性的文本,用于解释代码的含义、目的、用途、算法、实现方式等,通常用于提高代码的可读性和可维护性。但是在实际编程过程中,过量和不恰当的代码注释可能会导致以下影响: 代码冗余: 如果代码本身已经清晰易懂,但还增加了很多无用的注释,则会浪费磁盘空间和带宽。 注释过时: 如果…

    JavaScript 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部