Emacs集成ChatGPT:AI助手无缝融入编辑器工作流

news2026/5/14 23:04:01
1. 项目概述在Emacs中集成ChatGPT的魔法工具作为一名在Emacs生态里摸爬滚打了十多年的老用户我对于在编辑器里“折腾”各种生产力工具一直乐此不疲。当ChatGPT这类大语言模型LLM横空出世时我的第一反应就是这玩意儿要是能直接在我的Emacs里用起来那该多酷不用切浏览器不用离开我精心打造的编辑环境写代码、改文档、查资料、甚至生成shell命令都能无缝衔接。这就是我最初发现并尝试ChatGPT-Arcana这个Emacs包的动机。它就像一个给Emacs施放的“奥术”让你在编辑器内部直接获得AI助手的强大能力。虽然原作者已经归档了项目并推荐转向功能更全面的gptel但ChatGPT-Arcana作为一个早期的、轻量级的探索其设计思路和实现方式依然有很高的学习和参考价值尤其适合那些想了解如何在Emacs中深度集成AI功能或者需要一个简单、直接、可高度定制的起点的用户。简单来说ChatGPT-Arcana是一个Emacs包它通过OpenAI的API将ChatGPT的对话和文本处理能力直接嵌入到你的Emacs工作流中。它的核心价值在于“上下文感知”和“操作集成”你可以选中一段代码让它解释或重构可以在光标处根据上下文插入内容可以开启一个持久的聊天会话甚至可以让它帮你把自然语言描述转换成可执行的shell命令。这一切都发生在Emacs buffer里你的双手无需离开键盘。接下来我将结合自己的使用和探索经验为你深度拆解这个项目的设计、配置、实战应用以及那些官方文档里不会写的“坑”与技巧。2. 核心设计思路与架构解析2.1 为什么选择在Emacs内集成AI在深入代码之前我们先聊聊“为什么”。Emacs的核心哲学是“可扩展的操作系统”一切皆可定制、一切皆可集成。将AI能力集成进来是这一哲学的必然延伸。2.1.1 减少上下文切换损耗这是最直接的收益。当你正在专注编码时遇到一个复杂算法问题传统做法是AltTab到浏览器打开ChatGPT网页描述问题等待回复复制代码再切回Emacs。这个过程打断了深度工作流。而集成后你只需要一个快捷键比如C-c /在当前的代码buffer旁就会弹出一个AI聊天buffer问题自动带上代码上下文回答直接插入或替换原有代码。心智流Flow得以保持。2.1.2 利用Emacs强大的文本处理能力Emacs本身就是一个极其强大的文本处理引擎。AI生成的代码、文档可以立即用Emacs的各种模式如各种语言的major-mode, org-mode进行语法高亮、格式化、结构导航。你还可以用Emacs LispElisp对AI的输入输出进行后处理比如自动提取代码块、重命名变量、批量应用修改等形成自动化流水线。2.1.3 深度定制工作流这是开源包最大的优势。chatgpt-arcana提供了基础的API调用和buffer管理框架但如何触发、如何处理结果、如何展示完全由你的Elisp配置决定。你可以为不同的编程语言绑定不同的系统提示词System Prompt可以创建复杂的Hydra菜单来一键执行多种AI操作甚至可以将AI响应与你的项目管理工具如org-agenda联动。这种自由度是网页版或独立客户端无法比拟的。2.2 ChatGPT-Arcana的模块化设计从源码结构看ChatGPT-Arcana采用了核心加扩展Extras的模块化设计这是一种非常清晰和实用的架构。2.2.1 核心模块 (chatgpt-arcana.el)这是包的心脏负责最基础也是最关键的功能API通信封装与OpenAI Chat Completion API的交互处理HTTP请求、响应解析和错误处理。会话管理创建和管理独立的聊天buffer支持会话的自动保存、加载和命名。这是实现持久化对话的基础。上下文处理这是智能集成的关键。函数如chatgpt-arcana-insert-at-point-with-context会智能地抓取光标周围的代码或文本例如当前函数、段落并将其作为上下文提供给AI使得提问和回答都极具针对性。令牌Token溢出策略大语言模型有上下文窗口限制。当对话历史太长时核心模块提供了几种策略来处理如截断最早的消息、总结旧消息等确保对话能持续进行而不超出API限制。2.2.2 扩展模块 (Extras)这些是可选的、针对特定场景的增强功能通过require语句按需加载。这种设计避免了功能臃肿让用户可以根据自己的需求组合工具。chatgpt-arcana-eshell增加了spell命令。在Eshell中你可以输入spell “找出当前目录下所有昨天修改过的Python文件”它会调用AI生成相应的find或fd命令。这对于记忆复杂命令参数特别有用。chatgpt-arcana-autofix与Flycheck或Flymake这类实时语法检查工具集成。当光标位于错误或警告处时调用此命令AI会尝试理解错误信息并生成修复建议直接应用于代码。chatgpt-arcana-commitmsg集成Git分析暂存区的改动自动生成符合规范的提交信息。可以节省大量编写提交说明的时间。chatgpt-arcana-react这是一个非常实验性的功能尝试实现一个具有“工具使用”能力的AI代理。例如AI可以决定进行网页搜索或执行一段Elisp代码来获取信息从而完成更复杂的任务。这代表了更高级的AI集成方向。这种“核心插件”的架构使得ChatGPT-Arcana既保持了轻量又具备了强大的可扩展性是Emacs包设计的优秀范例。3. 从零开始的详细配置与安装指南虽然项目已归档但代码仓库依然可用。对于想尝鲜或学习的用户以下是完整的配置流程和深度解析。3.1 前置准备获取OpenAI API密钥这是使用任何OpenAI API服务的前提。安全性是首要考虑。访问平台前往OpenAI的官方网站注册并登录。创建API Key在账户的“API Keys”部分点击“Create new secret key”。为它起个名字比如“Emacs-Dev”。安全保存密钥只会显示一次务必立即复制并妥善保存。绝对不要将它直接硬编码在版本控制的配置文件中。重要安全实践我强烈建议在OpenAI控制台为这个密钥设置一个使用量限额Usage Limits。例如每月设置5美元或10美元的硬性上限。这能有效防止因配置错误、脚本循环或意外滥用导致的“天价账单”。AI API是按使用量计费的设置限额是负责任的使用习惯。3.2 安装ChatGPT-Arcana包由于不在MELPA等官方仓库我们使用straight.el或quelpa直接从GitHub安装。这里以流行的use-package配合straight.el为例。;; 在你的Emacs配置文件如 ~/.emacs.d/init.el 或 ~/.config/emacs/init.el中添加 (use-package chatgpt-arcana :straight (:host github :repo CarlQLange/chatgpt-arcana.el :files (*.el)) ; 指定安装.el文件 :init ;; 临时或测试用的密钥设置方式不推荐长期使用 ;; (setq chatgpt-arcana-api-key sk-你的真实API密钥) )配置解析:straight (...)指示straight.el从GitHub仓库直接克隆并编译安装。:files (“*.el”)确保只安装Elisp源文件忽略README等文档。:init在包加载前执行的代码。这里通常放置不依赖包功能的变量设置。3.3 安全的API密钥管理强烈推荐将密钥明文写在配置中是高风险行为。Emacs生态有成熟的安全解决方案auth-source。3.3.1 使用.authinfo.gpg或.netrc这是Unix系统的通用凭证存储方式Emacs的auth-source库可以安全读取。创建或编辑凭证文件# 在终端中编辑 ~/.authinfo 或 ~/.authinfo.gpg (推荐gpg加密) # 格式如下 machine api.openai.com login your-emailexample.com password sk-你的真实API密钥如果你使用.authinfo.gpg文件会被GPG自动加密解密安全性更高。在Emacs配置中安全读取(use-package chatgpt-arcana :straight (:host github :repo CarlQLange/chatgpt-arcana.el :files (*.el)) :init ;; 从auth-source读取密钥 (setq chatgpt-arcana-api-key (auth-source-pick-first-password :host api.openai.com)) ;; 可选如果读取失败提供一个明确的错误提示 (unless chatgpt-arcana-api-key (warn 无法从auth-source读取OpenAI API密钥请检查 ~/.authinfo 文件。)) )auth-source-pick-first-password函数会根据:host参数在你的凭证文件中查找对应的password字段并返回。3.3.2 使用环境变量另一种常见做法是通过系统环境变量传递密钥。在Shell配置中设置如~/.bashrc或~/.zshrcexport OPENAI_API_KEYsk-你的真实API密钥在Emacs配置中读取(use-package chatgpt-arcana :straight (...) :init (setq chatgpt-arcana-api-key (getenv OPENAI_API_KEY)) (unless chatgpt-arcana-api-key (warn 环境变量 OPENAI_API_KEY 未设置。)) )这种方法的好处是密钥完全不在Emacs配置文件中出现且可以被多个工具共享。3.4 个性化配置与键绑定安装并设置好密钥后就可以进行个性化定制了。原作者的配置示例提供了一个非常强大的起点我们逐一拆解。3.4.1 基础配置与UI增强(use-package chatgpt-arcana :straight (...) :init (setq chatgpt-arcana-api-key (auth-source-pick-first-password :host api.openai.com)) :config ; 在包加载*后*执行的代码 ;; 1. 为聊天模式添加一个漂亮的图标需要提前安装 all-the-icons 包 (use-package all-the-icons :config (add-to-list all-the-icons-mode-icon-alist (chatgpt-arcana-chat-mode all-the-icons-octicon comment-discussion :height 1.0 :v-adjust -0.1 :face all-the-icons-purple))) ;; 2. 自定义聊天自动保存目录 (setq chatgpt-arcana-chat-autosave-directory ~/.emacs.d/chatgpt-sessions/) ;; 确保目录存在 (unless (file-exists-p chatgpt-arcana-chat-autosave-directory) (make-directory chatgpt-arcana-chat-autosave-directory t)) ;; 3. 设置令牌溢出策略当对话太长时自动总结旧消息以节省令牌 (setq chatgpt-arcana-token-overflow-strategy summarize) (setq chatgpt-arcana-token-overflow-token-goal 2000) ; 目标保留约2000个令牌的历史 ;; 4. 自定义常用提示词列表 - 这是提升效率的关键 (setq chatgpt-arcana-common-prompts-alist ((refactor . 请重构以下代码提高其可读性和性能并保持原有功能。只返回重构后的代码不要解释。) (explain . 请用中文清晰解释以下代码的功能和逻辑。) (document . 为以下函数或代码块编写完整的文档字符串Docstring。) (debug . 以下代码可能存在错误或潜在问题请指出并给出修复建议。) (test . 为以下函数编写单元测试用例。) )):config部分在这里执行依赖包功能的配置。例如设置基于包内定义的变量或调用包提供的函数。常用提示词chatgpt-arcana-common-prompts-alist是一个核心配置。它定义了一组别名和对应的提示词模板。之后你可以通过chatgpt-arcana-query函数并指定别名来快速使用这些模板极大提升了交互效率。3.4.2 创建高效的Hydra菜单Hydra是一个可以创建临时、模式化快捷键菜单的包非常适合组织大量相关命令。原配置中的chatgpt-arcana-generate-prompt-shortcuts函数和pretty-hydra-define部分展示了如何动态生成一个美观的AI操作面板。;; 定义一个函数根据常用提示词列表自动生成Hydra命令 (defun my/chatgpt-arcana-generate-prompt-shortcuts () “根据常用提示词列表生成Hydra命令。” (mapcar (lambda (prompt-pair) (let* ((id (car prompt-pair)) ; 例如 ‘refactor (label (capitalize (symbol-name id))) ; 转换为 “Refactor” (key (concat “s” (substring (symbol-name id) 0 1))) ; 生成快捷键如 “sr” (prompt-text (cdr prompt-pair)) (command (,key (lambda () (interactive) (chatgpt-arcana-query ,prompt-text)) ,label))) command)) chatgpt-arcana-common-prompts-alist)) (use-package pretty-hydra :config (pretty-hydra-define my-chatgpt-hydra (:color blue :quit-key “q” :title “ChatGPT Arcana 控制台” :foreign-keys warn) (“核心操作” ((“a” chatgpt-arcana-query “自由提问”) (“r” chatgpt-arcana-replace-region “替换选中区域”) (“c” chatgpt-arcana-start-chat “开启新聊天会话”) (“f” chatgpt-arcana-autofix “自动修复错误需加载extras”)) “插入操作” ((“i” chatgpt-arcana-insert-at-point-with-context “在光标处插入带上下文”) (“I” chatgpt-arcana-insert-at-point “在光标处插入”) (“j” chatgpt-arcana-insert-after-region “在选中区域后插入”) (“J” chatgpt-arcana-insert-before-region “在选中区域前插入”)) “提示词快捷方式” ,(my/chatgpt-arcana-generate-prompt-shortcuts) ; 动态插入生成的快捷命令 )))配置完成后按下你绑定的快捷键如原配置中的leader[ h就会弹出一个彩色分类的Hydra菜单。按r执行替换按sr即先按s再按r使用“重构”提示词按q退出菜单。这种设计将分散的命令集中管理直观且高效。3.4.3 键绑定建议键绑定是非常个人化的。原配置使用了general.el通过map!宏你也可以用内置的global-set-key或define-key。;; 使用 general.el (流行且强大的键绑定管理包) (use-package general) (general-create-definer my-leader-def :states ‘normal :keymaps ‘override :prefix “SPC”) ; 设置Leader键为空格 (my-leader-def “/” ‘(:ignore t :which-key “AI助手”) “/ c” ‘chatgpt-arcana-start-chat “/ q” ‘chatgpt-arcana-query “/ r” ‘chatgpt-arcana-replace-region “/ h” ‘my-chatgpt-hydra/body ; 呼出上面定义的Hydra菜单 )这个绑定方案将AI助手功能统一在SPC /前缀下逻辑清晰不易冲突。4. 核心功能实战与深度应用技巧配置妥当后让我们进入实战环节。ChatGPT-Arcana的功能看似简单但结合Emacs的特性可以玩出很多花样。4.1 智能代码操作超越简单的问答4.1.1 区域替换 (chatgpt-arcana-replace-region)这是最常用的功能之一。选中一段代码调用该命令输入你的指令如“用更Pythonic的方式重写这个循环”AI生成的内容会直接替换掉选中部分。实战技巧对于复杂的重构指令要具体。不要只说“优化代码”而要说“将这部分嵌套循环改为使用列表推导式并添加错误处理”。注意事项替换前务必确认选中了正确的区域。建议先保存文件或者使用Emacs的撤销功能C-/以防不满意。对于关键代码可以先在聊天会话中让AI解释其修改意图确认无误后再应用。4.1.2 带上下文的插入 (chatgpt-arcana-insert-at-point-with-context)这个功能极其强大。它不会替换你的代码而是在光标处插入AI生成的内容并且会自动将光标附近的代码如当前函数作为上下文发送给AI。使用场景编写函数注释光标放在函数定义行调用命令输入“生成docstring”AI会根据函数体生成准确的文档字符串。补全代码逻辑在编写一个函数到一半时在合适位置调用输入“完成这个函数实现XXX功能”。编写测试光标在函数内输入“为这个函数生成pytest单元测试”。原理剖析该函数内部通常会调用bounds-of-thing-at-point来获取“当前事物”如‘defun表示函数的起止位置然后将这段文本作为上下文附加到你的问题前。这意味着你的问题可以非常简短AI却能基于完整上下文给出精准回答。4.1.3 与版本控制集成结合magitEmacs中最好的Git前端你可以打造流畅的AI辅助开发流。修改代码后用magit暂存Stage更改。调用chatgpt-arcana-commitmsg需加载extras。AI会分析diff并生成提交信息。在生成的提交信息buffer中直接编辑并确认提交。 这个过程将代码修改、AI辅助总结、版本提交无缝串联。4.2 持久化聊天会话你的项目专属顾问chatgpt-arcana-start-chat会创建一个独立的buffer这是一个完整的、带历史的聊天界面。会话自动保存启用chatgpt-arcana-chat-autosave-enabled后每次对话都会自动保存到指定目录。你可以随时关闭Emacs下次打开时加载之前的会话继续聊。这对于长期、复杂的项目讨论非常有用。缓冲区命名AI可以根据初始对话内容自动为聊天buffer生成一个描述性名称通过chatgpt-arcana-generated-buffer-name-prompt定制方便你在多个会话间切换。多会话管理你可以为不同的任务开启不同的聊天buffer例如一个用于前端CSS问题一个用于后端算法讨论。利用Emacs的buffer切换机制如ido-switch-buffer,ivy轻松管理。4.3 Eshell集成自然语言命令生成加载extras/chatgpt-arcana-eshell后在Eshell中你就拥有了spell这个“魔法”命令。~ $ spell “将所有.jpg图片转换为.webp格式保持质量在80%” # AI可能会返回find . -name “*.jpg” -exec sh -c ‘convert “$0” “${0%.jpg}.webp” -quality 80’ {} \; # 或者使用更现代的fd -e jpg -x convert {} {.}.webp -quality 80安全第一永远不要盲目执行AI生成的shell命令尤其是涉及rm,mv,chmod, 或数据操作的命令。务必先理解命令的作用对于不熟悉的命令可以先在安全环境测试或使用echo预览命令展开结果。最佳实践将spell视为一个强大的“命令学习工具”。当它生成一个复杂的find或awk命令时花点时间理解每个参数的含义这比单纯记忆命令更有效。4.4 错误自动修复与Flycheck/Flymake联动对于支持LSP或语法检查的语言如Python, JavaScript, GoFlycheck能实时标出错误。将光标移到错误处调用chatgpt-arcana-autofixAI会尝试理解错误信息并给出修复建议。局限性AI并非总能正确修复尤其是复杂的逻辑错误或涉及项目特定架构的问题。它更擅长修复语法错误、简单的类型错误或提供常见的修复模式。使用策略将其视为“第一响应”工具。对于简单的错误它可能直接解决对于复杂错误它提供的建议可以作为一个有用的调试起点你需要结合自己的判断来采纳。5. 常见问题、故障排查与进阶技巧在实际使用中你肯定会遇到各种问题。以下是我踩过的一些坑和总结的解决方案。5.1 网络与API相关问题问题现象可能原因排查与解决错误:Failed to get response或curl error1. API密钥错误或未设置。2. 网络连接问题代理、防火墙。3. OpenAI服务暂时不可用。1. 检查chatgpt-arcana-api-key变量值是否正确。用M-x describe-variable RET chatgpt-arcana-api-key查看。2. 在Emacs中尝试M-x shell用curl测试连通性curl https://api.openai.com/v1/models -H “Authorization: Bearer YOUR_KEY”。3. 检查OpenAI状态页面。错误:Incorrect API key providedAPI密钥格式错误或已失效。1. 确认密钥以sk-开头。2. 前往OpenAI控制台确认密钥未被删除或禁用。3. 如果使用环境变量或auth-source确认Emacs进程能读取到正确的值可能需要重启Emacs。响应速度极慢或超时1. 网络延迟高。2. 请求的上下文Token过长。3. OpenAI API服务器负载高。1. 设置chatgpt-arcana-request-timeout变量调高超时时间默认可能30秒。2. 对于长文档操作考虑先拆分再处理。3. 使用chatgpt-arcana-token-overflow-strategy为’summarize或’truncate来控制上下文长度。5.2 Emacs与包配置问题问题现象可能原因排查与解决chatgpt-arcana-...命令未找到包未成功加载或加载顺序问题。1. 检查use-package声明是否有语法错误:straight是否成功安装。2. 查看*Messages*buffer (C-h e) 是否有加载错误。3. 尝试M-x load-library RET chatgpt-arcana手动加载。Hydra菜单或键绑定不生效1. 依赖包如pretty-hydra,general.el未安装。2. 键绑定与其他包冲突。1. 确保use-package声明中正确声明了依赖。2. 使用C-h k后按你绑定的快捷键查看哪个命令被实际触发。3. 简化配置先测试核心命令如M-x chatgpt-arcana-query是否工作。聊天Buffer没有自动保存相关变量未设置或路径权限问题。1. 确认chatgpt-arcana-chat-autosave-enabled设为t。2. 检查chatgpt-arcana-chat-autosave-directory指向的目录是否存在且Emacs有写入权限。3. 查看该目录下是否生成了.chat后缀的保存文件。5.3 模型与内容生成问题问题现象可能原因排查与解决AI回答质量差或答非所问1. 提示词Prompt不清晰。2. 提供的上下文不完整或无关。3. 模型本身局限性。1.优化提示词遵循“角色-任务-格式”结构。例如“你是一个资深Python开发者。请将以下函数重构为使用异步IO。只返回重构后的代码不要解释。”2.提供充足上下文使用-with-context系列命令或手动在聊天中粘贴相关代码。3.尝试调整温度Temperature包可能未暴露此参数但如果是直接调用API较低温度如0.2使输出更确定较高温度如0.8更有创造性。AI生成的代码有语法错误模型在复杂逻辑或罕见库上可能出错。1.始终进行审查和测试AI是助手不是替代品。生成的代码必须经过你的审查和运行测试。2.迭代优化如果代码有误将错误信息反馈给AI在聊天会话中让它自行修正。这是一个很好的调试学习过程。处理长文档时中断或响应不完整超出模型上下文窗口如GPT-3.5-turbo的4096 tokens。1.主动拆分对于长文档手动拆分成多个部分分别处理。2.使用总结策略设置chatgpt-arcana-token-overflow-strategy为’summarize让AI自动压缩旧对话。3.升级模型如果使用GPT-4 API其上下文窗口更大如8K, 32K但费用也更高。5.4 进阶技巧与自定义扩展当你熟悉基础功能后可以尝试以下进阶玩法1. 创建领域特定的提示词模板在你的配置中扩展chatgpt-arcana-common-prompts-alist加入针对你主要工作语言的提示词。(setq chatgpt-arcana-common-prompts-alist ‘((py-doc . “为以下Python函数生成Google风格的docstring包含Args、Returns和Raises部分。”) (js-async . “将以下JavaScript回调函数改为使用async/await语法。”) (sql-optimize . “分析以下SQL查询指出潜在的性能瓶颈并提供优化建议。”) (org-outline . “将以下杂乱的想法组织成一个层次清晰的org-mode大纲。”) ))2. 与Org-mode深度集成你可以编写一个函数将Org subtree的内容发送给AI处理并将结果插入为新的subtree或属性。(defun my/org-ask-ai-about-subtree () “将当前Org子树的内容发送给ChatGPT进行提问。” (interactive) (let ((content (org-get-entry))) (when content (chatgpt-arcana-query (concat “关于以下内容请提供详细解释和补充\n” content))))) (define-key org-mode-map (kbd “C-c a”) ‘my/org-ask-ai-about-subtree)3. 自定义请求参数虽然包可能没有暴露所有参数但你可以通过覆写内部函数或提交PR来增加控制。例如修改请求的模型、温度temperature、最大令牌数等。这需要一定的Elisp能力但能让你更精细地控制AI行为。4. 探索替代后端ChatGPT-Arcana的核心是与OpenAI API通信。理论上你可以修改其请求函数使其兼容其他提供OpenAI格式API的本地或开源模型如通过Ollama、LM Studio部署的Llama、Mistral等。这需要修改chatgpt-arcana--request等函数中的端点URL和参数。这是一个高级定制方向可以让你在离线或特定环境下使用。6. 项目现状与未来方向正如项目仓库首页的“归档通知”所言作者Carl Lange已转向使用功能更全面、实现更优雅的gptel包。这是一个明智的选择。gptel支持更多的模型提供商OpenAI, Anthropic Claude, Gemini, 本地模型等具有更现代化的架构和活跃的维护。那么今天学习ChatGPT-Arcana还有意义吗我的回答是绝对有。对于Emacs用户和Elisp学习者来说ChatGPT-Arcana是一个绝佳的“教学案例”。它的代码量相对较小结构清晰完整地展示了一个实用的、与外部Web服务交互的Emacs包是如何构建的。你可以在其中学习到如何设计异步HTTP请求避免阻塞Emacs主线程。如何管理Emacs buffer和进程实现交互式聊天。如何设计用户配置变量和自定义函数。如何实现“上下文感知”这种智能编辑功能。你可以将ChatGPT-Arcana视为一个功能完整的“起点”。如果你只需要基础的ChatGPT集成它完全够用。如果你需要更多功能可以研究它的代码并将好的思路应用到自己的配置中或者直接为gptel等更活跃的项目贡献代码。最终无论是使用ChatGPT-Arcana、gptel还是自己动手编写在Emacs中集成AI能力的核心目标是不变的创造一个无缝的、可定制的、以键盘为中心的工作环境让强大的AI模型成为你思维过程的自然延伸而不是一个需要你频繁切换上下文的外部工具。这个过程本身就是Emacs精神在AI时代的一次生动实践。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2609285.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…