在 IntelliJ IDEA 中开发 GPT 自动补全插件
背景与目标
随着 AI 的发展,GitHub Copilot 等智能代码补全工具在开发者中获得了广泛的应用,极大地提高了编程效率。本篇文章将教你如何开发一个 IntelliJ IDEA 插件,使用 OpenAI 的 GPT API 来实现类似 Copilot 的代码自动补全功能。通过这个插件,开发者可以在编写代码时,借助 GPT 的智能算法,快速获取代码建议。
主要目标:
- 创建一个 IntelliJ IDEA 插件。
- 集成 OpenAI GPT API,实现代码补全功能。
- 实时生成代码建议,辅助开发者编写代码。
开发步骤
1. 创建 IntelliJ IDEA 插件项目
首先,我们需要在 IntelliJ IDEA 中创建一个插件项目:
- 打开 IntelliJ IDEA,选择 New Project。
- 选择 IntelliJ Platform Plugin 类型。
- 填写插件的名称、版本、描述等信息,点击 Create。
2. 配置插件的 plugin.xml 文件
在插件项目的 src/main/resources/META-INF/plugin.xml 中,定义插件的基本信息,如插件名称、描述、依赖等。
<idea-plugin><id>com.example.gptplugin</id><name>GPT Code Assistant</name><vendor email="your-email@example.com">Your Name</vendor><description>A plugin that integrates GPT to assist with code completion</description><depends>com.intellij.modules.platform</depends><extensions defaultExtensionNs="com.intellij"><completion.contributor implementation="com.example.gptplugin.GPTCompletionContributor" /></extensions>
</idea-plugin>
3. 配置依赖
在 build.gradle 文件中添加所需的依赖,包括 OkHttp(用于发送 HTTP 请求)和 Gson(用于解析 JSON)。
plugins {id 'java'id 'org.jetbrains.intellij' version '1.8.0'
}repositories {mavenCentral()
}dependencies {implementation 'com.squareup.okhttp3:okhttp:4.9.0'implementation 'com.google.code.gson:gson:2.8.8'
}intellij {version '2021.1'
}
4. 创建 GPTClient 用于调用 GPT API
接下来,编写一个 GPTClient 类,用于向 OpenAI API 发送请求并获取返回的代码建议。
import okhttp3.*;
import com.google.gson.*;import java.io.IOException;public class GPTClient {private static final String API_KEY = "YOUR_API_KEY"; // 用你自己的 API 密钥替换private static final String API_URL = "https://api.openai.com/v1/completions";private OkHttpClient client;private Gson gson;public GPTClient() {client = new OkHttpClient();gson = new Gson();}public String getCodeSuggestion(String prompt) throws IOException {JsonObject requestBody = new JsonObject();requestBody.addProperty("model", "text-davinci-003");requestBody.addProperty("prompt", prompt);requestBody.addProperty("max_tokens", 100);requestBody.addProperty("temperature", 0.5);RequestBody body = RequestBody.create(requestBody.toString(), MediaType.get("application/json"));Request request = new Request.Builder().url(API_URL).header("Authorization", "Bearer " + API_KEY).post(body).build();try (Response response = client.newCall(request).execute()) {if (!response.isSuccessful()) {throw new IOException("Unexpected code " + response);}String responseBody = response.body().string();JsonObject responseJson = gson.fromJson(responseBody, JsonObject.class);return responseJson.getAsJsonArray("choices").get(0).getAsJsonObject().get("text").getAsString();}}
}
5. 实现 CompletionContributor 提供代码补全
为了在 IntelliJ IDEA 中实现代码自动补全功能,我们需要创建一个 CompletionContributor 类。在这个类中,我们将使用 GPT API 根据用户输入的上下文生成代码建议,并显示在补全列表中。
import com.intellij.codeInsight.lookup.LookupElement;
import com.intellij.codeInsight.lookup.LookupElementBuilder;
import com.intellij.codeInsight.lookup.LookupResult;
import com.intellij.codeInsight.lookup.LookupElement;
import com.intellij.codeInsight.lookup.Lookup;import com.intellij.openapi.editor.Editor;
import com.intellij.openapi.project.Project;
import com.intellij.psi.PsiFile;
import com.intellij.util.Processor;public class GPTCompletionContributor extends CompletionContributor {@Overridepublic void fillCompletionVariants(CompletionParameters parameters, Processor<CompletionResult> result) {PsiFile file = parameters.getOriginalFile();Project project = parameters.getPosition().getProject();if (file.getFileType().getName().equals("JAVA") || file.getFileType().getName().equals("KOTLIN")) {String textBeforeCaret = parameters.getPosition().getText().substring(0, parameters.getOffset());String prompt = generatePromptFromText(textBeforeCaret);try {GPTClient gptClient = new GPTClient();String codeSuggestion = gptClient.getCodeSuggestion(prompt);LookupElement lookupElement = LookupElementBuilder.create(codeSuggestion).withTypeText("Generated by GPT").withInsertHandler((context, item) -> {context.getDocument().insertString(context.getStartOffset(), codeSuggestion);});result.process(lookupElement);} catch (Exception e) {e.printStackTrace();}}}private String generatePromptFromText(String text) {return "Suggest a code completion for this: " + text;}
}
6. 配置插件快捷键或菜单项
为了使插件更加用户友好,可以为代码补全功能配置快捷键或菜单项。以下是一个简单的配置示例,将快捷键 Ctrl+Alt+G 设置为触发补全功能。
<actions><action id="GPTCodeCompletion"class="com.example.gptplugin.GPTCompletionContributor"text="Complete Code with GPT"description="Generate code completions using GPT-3"icon="icons/gpt_icon.png"><keyboard-shortcut keymap="$default" first-keystroke="ctrl alt G"/></action>
</actions>
7. 测试和调试插件
- 点击 Run 按钮,在新的 IntelliJ IDEA 实例中测试插件。
- 输入代码并按下快捷键
Ctrl+Alt+G,检查 GPT 是否成功生成代码补全建议并插入到编辑器中。
8. 发布插件
一旦插件完成并经过测试,你可以通过 JetBrains 插件市场将其发布,或者将插件打包并直接分发给其他用户。
总结
通过上述步骤,你已经成功创建了一个 IntelliJ IDEA 插件,它能够调用 GPT API 提供代码自动补全功能。这个插件的主要流程包括:
- 创建插件项目,并配置基本的插件信息。
- 集成 GPT API,获取代码补全建议。
- 使用
CompletionContributor类提供代码补全。 - 配置快捷键或菜单项触发补全功能。
- 测试并发布插件。
这种基于 GPT 的代码自动补全插件可以大大提高开发效率,尤其是在编写常见功能或模板时,可以自动生成高质量的代码补全建议。
相关文章:
在 IntelliJ IDEA 中开发 GPT 自动补全插件
背景与目标 随着 AI 的发展,GitHub Copilot 等智能代码补全工具在开发者中获得了广泛的应用,极大地提高了编程效率。本篇文章将教你如何开发一个 IntelliJ IDEA 插件,使用 OpenAI 的 GPT API 来实现类似 Copilot 的代码自动补全功能。通过这…...
7. C语言 运算符详解
本章目录: 前言C语言运算符的分类1. 算术运算符2. 关系运算符3. 逻辑运算符4. 位运算符5. 赋值运算符6. 杂项运算符 运算符优先级 前言 在C语言中,运算符是程序中执行各种操作的核心工具,涉及算术运算、逻辑判断、位操作等多个方面。掌握C语言中的各种运…...
Java四大常用JSON解析性能对比:Hutool、Fastjson2、Gson与Jackson测试
1. 引言 JSON 是现代软件开发中常用的数据交换格式,尤其在微服务和前后端分离的架构中更是必不可少。 本文将对 Java 中四大主流 JSON 解析库——Hutool、Fastjson2、Gson 和 Jackson 进行性能测试和对比分析,通过实测 20 万条数据解析,揭示…...
Qt 5.14.2 学习记录 —— 일 新项目
文章目录 1、创建2、查看代码 ---- main.cpp3、查看代码 ---- widgt.h4、查看代码 ---- widgt.cpp和widget.ui5、查看代码 ---- Empty.pro6、运行产生的中间文件 1、创建 左上角的文件,新建文件或项目。如果要写一个GUI程序,应当选择Application&#x…...
uni-app:实现普通选择器,时间选择器,日期选择器,多列选择器
效果 选择前效果 1、时间选择器 2、日期选择器 3、普通选择器 4、多列选择器 选择后效果 代码 <template><!-- 时间选择器 --><view class"line"><view classitem1><view classleft>时间</view><view class"right&quo…...
Unity3D仿星露谷物语开发17之空库存栏UI
1、目标 将库存栏放在游戏界面中,一般情况下角色居中展示时库存栏在底部,当角色位于界面下方时库存栏展示在顶部避免遮挡。 2、CanvasGroup组件 用于集中控制UI元素的透明度、交互性和射线投射行为。CanvasGroup的Alpha属性允许渐变效果,I…...
QT------模型/视图
一、模型/视图结构概述 基本原理: Qt 的模型/视图(Model/View)架构将数据的存储和显示分离,提高了代码的可维护性和复用性。模型(Model):负责存储和管理数据,提供数据的访问接口&am…...
Git - 记录一次由于少输入了一个命令导致的更改丢失
Git - 记录一次由于少输入了一个参数导致的更改丢失 前言 某晚我激情开发了几个小时,中途没有进行commit存档。准备睡觉时,我想创建一个新的分支并将今晚所有更改提交到新分支上(似乎应该开发时候就创建?)。 然后因…...
nodeJS下npm和yarn的关系和区别详解
一、命令对应关系 1. 初始化项目 操作npm 命令Yarn 命令初始化项目npm inityarn init跳过提问快速初始化npm init -yyarn init -y 2. 安装依赖 操作npm 命令Yarn 命令安装项目所有依赖npm installyarn install添加依赖npm install <package-name>yarn add <package…...
党员学习交流平台
本文结尾处获取源码。 本文结尾处获取源码。 本文结尾处获取源码。 一、相关技术 后端:Java、JavaWeb / Springboot。前端:Vue、HTML / CSS / Javascript 等。数据库:MySQL 二、相关软件(列出的软件其一均可运行) I…...
HTML5 文件上传(File Upload)详解
HTML5 文件上传(File Upload)详解 HTML5 提供了强大的文件上传功能,允许用户通过网页选择文件并上传到服务器。以下是关于文件上传控件的详细说明。 1. 基本的文件上传控件 使用 <input> 标签的 type"file" 属性可以创建一…...
1.2.1-2部分数据结构的说明02_链表
(1)链表数据结构: 概念: 将列表中相互连接的节点不连续的存储在内存中。与数据不同,我们无法再恒定时间内访问任何元组,如果遍历所有则花费时间与元素总数n成正比。插入和删除1个元素的时间复杂度都是O(n…...
vue elementUI Plus实现拖拽流程图,不引入插件,纯手写实现。
vue elementUI Plus实现拖拽流程图,不引入插件,纯手写实现。 1.设计思路:2.设计细节3.详细代码实现 1.设计思路: 左侧button列表是要拖拽的组件。中间是拖拽后的流程图。右侧是拖拽后的数据列表。 我们拖动左侧组件放入中间的流…...
linux上使用cmake编译的方法
一、hello 例程仅基于一个cpp文件 C文件或工程进行编译时可以使用g指令(需要对每一个程序和源文件分别使用g指令编译),当程序变大时,一个工程文件往往会包含很文件夹和源文件,这时我们需要的编译指令将越来越长&#…...
如何实现el-select多选下拉框中嵌套复选框并加校验不为空功能呢?
如何实现el-select多选下拉框中嵌套复选框并加校验不为空功能呢? 要实现的效果图选择部分品牌但不选选项效果问题概述实现方案el-select组件与el-checkbox组件无缝衔接给form表单加自定义校验规则 要实现的效果图 选择部分品牌但不选选项效果 问题概述 相信大家看到…...
源码理解 UE4中的 FCookStatsManager::FAutoRegisterCallback RegisterCookStats
官方文档:https://dev.epicgames.com/documentation/zh-cn/unreal-engine/API/Runtime/Core/ProfilingDebugging/FCookStatsManager文档中的注释: When a cook a complete that is configured to use stats (ENABLE_COOK_STATS), it will broadcast this…...
Android 根据内存大小显示MTP模式连接PC时的名称
项目有两种内存,要求根据连接电脑拷贝文件时的盘符名称根据内存大小显示不同名称。 frameworks/base/media/java/android/mtp/MtpDatabase.java//mh import android.app.ActivityManager; ...-894,7 896,19 public class MtpDatabase implements AutoCloseable {p…...
不只是mini-react第一节:实现最简单mini-react
项目总结构: ├─ 📁core │ ├─ 📄React.js │ └─ 📄ReactDom.js ├─ 📁node_modules ├─ 📁tests │ └─ 📄createElement.spec.js ├─ 📄App.js ├─ 📄in…...
前端路由layout布局处理以及菜单交互(三)
上篇介绍了前端项目部署以及基本依赖的应用,这次主要对于路由以及布局进行模块化处理 一、 创建layout模块 1、新建src/layout/index.vue <template><el-container class"common-layout"><!-- <el-aside class"aside">&l…...
小结:DNS,HTTP,SMTP,IMAP,FTP,Telnet,TCP,ARP,ICMP
DNS(Domain Name System,域名系统) 是互联网的重要组成部分,它负责将人类易读的域名(如 www.google.com)转换为机器可以识别的 IP 地址(如 142.250.72.206)。这一过程被称为域名解析…...
RDMA不只是‘快’:深入聊聊它在Spark、MySQL等真实业务场景下的性能陷阱与优化实践
RDMA不只是‘快’:深入聊聊它在Spark、MySQL等真实业务场景下的性能陷阱与优化实践 当技术团队第一次接触RDMA(远程直接内存访问)时,往往会被其宣传的"零拷贝"、"低延迟"特性所吸引。然而在实际部署到Spark S…...
手把手教你调TSL1401线性CCD的曝光时间,让STM32智能小车循迹更稳
STM32智能小车CCD循迹曝光时间优化实战指南 从理论到实践:曝光时间对CCD循迹的影响机制 调试过TSL1401线性CCD的开发者都深有体会——曝光时间这个看似简单的参数,实际影响着整个循迹系统的稳定性。当小车在赛道上出现"蛇形走位"或突然丢线时&…...
别再调参了!SITS2026已淘汰微调依赖——揭秘Zero-Shot Contextual Inference引擎如何实现跨项目零样本泛化(附VS Code插件预览版申请通道)
第一章:SITS2026深度解读:代码补全技术演进 2026奇点智能技术大会(https://ml-summit.org) SITS2026(Software Intelligence & Tooling Summit 2026)首次系统性地将代码补全技术划分为“感知—推理—协同”三阶段范式&#…...
TorchMetrics部署指南:从开发到生产环境的完整流程
TorchMetrics部署指南:从开发到生产环境的完整流程 【免费下载链接】torchmetrics Machine learning metrics for distributed, scalable PyTorch applications. 项目地址: https://gitcode.com/gh_mirrors/to/torchmetrics TorchMetrics是一个为分布式、可扩…...
mysql如何进行全量数据库备份_mysqldump工具的使用技巧
备份前必须确认用户具备SELECT、LOCK TABLES、RELOAD权限,且MySQL未启用read_onlyON、max_allowed_packet足够大;全量备份需加--routines、--events、--triggers、--single-transaction和--set-gtid-purgedOFF。备份前必须确认的三个权限和状态用 mysqld…...
多轮任务型对话驱动的虚拟员工核心代码 带完整的搭建部署教程
温馨提示:文末有资源获取方式最近圈子里有个东西特别火,到处都在说。但说实话,普通人想真正用起来,门槛还是挺高的——要懂代码、要配置环境、还要养着它,一个月光消耗成本少则一两百,多则上千。很多人跟风…...
微信UI树“隐身”之谜:逆向UIA暴露策略与AI-RPA融合实战
1. 微信UI树“隐身”背后的技术博弈 去年帮客户做微信自动化项目时,突然发现用了几年的pywinauto脚本集体罢工。调试时打开Inspect工具一看,原本密密麻麻的UI树突然变得光秃秃的,就像被施了隐身术。这种变化不是偶然的bug,而是微信…...
告别Excel手工作坊:用Tableau Prep Builder 2024.1自动化清洗销售数据的保姆级教程
告别Excel手工作坊:用Tableau Prep Builder 2024.1自动化清洗销售数据的保姆级教程 销售数据就像一座金矿,但大多数时候我们却用勺子而不是挖掘机在开采。想象一下这样的场景:每月底,你从CRM系统导出客户订单,从财务系…...
生成式AI实时通信的“隐形瓶颈”:模型Tokenizer流式切分与网络MTU错配问题(附Wireshark抓包取证全过程)
第一章:生成式AI应用实时通信方案 2026奇点智能技术大会(https://ml-summit.org) 生成式AI应用对低延迟、高并发、上下文感知的实时通信能力提出全新要求。传统REST API轮询或短连接模式难以支撑流式推理响应、多模态协同编辑、Agent间动态协商等典型场景。现代架构…...
算网融合,互联无界:丰润达亮相第三届AI算力产业大会
丰润达亮相第三届AI算力产业大会,带来一场关于算力落地的不同思考。 2026年4月9日,深圳福田会展中心,第三届AI算力产业大会如期开幕。华为、百度、阿里、腾讯、浪潮等科技巨头悉数亮相,在众多厂商展示更强算力集群的同时…...
