AI编码助手技能库开发指南:从提示词到自动化工作流

news2026/5/4 23:34:40
1. 项目概述为AI编码助手打造的个人技能库如果你和我一样日常重度依赖 Claude Code、Cursor 这类 AI 编码助手那你一定遇到过这样的场景想让 AI 帮你设计一个 API 接口或者生成一份项目文档你需要在聊天框里反复描述你的需求、格式要求、甚至是一些固定的模板。每次都要重新解释一遍效率低下不说还容易遗漏细节。Cortex AI Skills 这个项目就是为了解决这个痛点而生的。它本质上是一个个人工作流的技能库你可以把它理解为给 Claude Code、Cursor 这类工具安装的“插件”或“宏命令”。通过预定义好的技能Skill你只需要输入一个简单的斜杠命令比如/api-designerAI 就能立刻理解你的完整意图并按照你预设的最佳实践来输出结果。这个项目由开发者 alexander-danilenko 维护虽然作者强调这是为其个人工作流定制的技能集但其设计思路和实现方式具有很高的参考价值。它不仅仅是一堆脚本的集合更体现了一种如何系统化地扩展和定制 AI 助手能力的方法论。无论你是想直接使用这些现成的技能来提升效率还是想借鉴其架构来构建属于自己的技能库这个项目都是一个绝佳的起点。接下来我将为你深入拆解它的核心设计、安装使用细节、开发扩展方法并分享我在适配和创建类似技能过程中的实战经验与避坑指南。2. 核心设计理念与架构解析2.1 什么是“AI技能”及其价值所在在讨论 Cortex AI Skills 之前我们需要先厘清一个概念在 AI 编码助手的语境下“技能”到底是什么它不是一个可以独立运行的应用程序也不是一个后台服务。简单来说一个技能就是一段高度结构化、目标明确的提示词Prompt模板通常还附带一些执行上下文如可访问的文件、允许执行的操作和元数据如技能名称、描述、参数。它的核心价值在于“封装”和“复用”。举个例子写 API 文档这件事包含很多固定要素端点路径、HTTP 方法、请求/响应格式、状态码、示例等。一个成熟的开发者心中有一套撰写 API 文档的“最佳实践”。通过技能你可以将这套“最佳实践”固化下来。当你触发/api-designer技能时AI 接收到的不是一个简单的“帮我写 API”指令而是一个包含了详细角色设定“你是一个专业的 API 设计师”、任务步骤“首先分析需求然后定义资源模型…”、输出格式要求“使用 OpenAPI 3.0 格式包含请求体示例…”的完整任务包。这极大地减少了模糊性提高了输出结果的一致性和质量。Cortex AI Skills 项目采用了一种松散但实用的架构。它没有复杂的后端或数据库其核心就是一个遵循特定目录结构的代码仓库。每个技能通常以一个独立的文件如.md或.json存在里面包含了该技能的所有定义。这种设计使得技能的创建、分享和安装变得极其轻量。2.2 技能生态与工具链整合这个项目的另一个巧妙之处在于它积极融入了现有的工具生态。它主要支持两种安装和管理方式分别对应不同的使用场景和工具作为 Claude Code 插件这是最原生的集成方式。Claude Code 提供了官方的插件市场机制。Cortex AI Skills 将自己打包成一个插件用户可以通过claude plugin命令行工具直接从市场安装。安装后技能会无缝集成到 Claude Code 的聊天界面中以斜杠命令的形式调用。这种方式体验最好技能更新也方便。通过npx skills工具这是一个更通用、更灵活的方式。npx skills是一个第三方开发的技能管理工具它像一个包管理器可以从多个源GitHub 仓库安装技能并部署到不同的 AI 代理如 Claude Code, Cursor。Cortex AI Skills 也兼容这种方式。它的优势在于不局限于 Claude Code可以用于 Cursor 等其他支持类似功能的编辑器并且可以方便地混合安装来自不同仓库的技能。项目文档中还推荐了其他优秀的技能仓库如 Anthropic 官方的技能库和obra/superpowers。这反映了一个健康的生态观不要试图造一个包含一切技能的全能轮子而是专注于创建自己最擅长、最需要的技能同时鼓励用户从多个优质源获取技能。这种模块化、可组合的思想是构建可持续个人效率系统的关键。3. 详细安装与配置指南3.1 方式一作为 Claude Code 插件安装推荐用于 Claude Code 用户这是为 Claude Code 用户准备的最直接路径。确保你已经在系统上安装并配置好了 Claude Code 的命令行工具claude。步骤 1添加技能市场首先你需要将 Cortex AI Skills 的仓库地址添加到 Claude Code 的插件市场中。打开终端执行以下命令claude plugin marketplace add alexander-danilenko/cortex-ai-skills这个命令会告诉 Claude Code“我知道有一个叫alexander-danilenko/cortex-ai-skills的插件源请把它加入我的市场列表。” 执行成功后通常不会有太花哨的提示你可以通过claude plugin marketplace list来确认它是否已在列表中。步骤 2安装技能插件接下来从刚添加的市场中安装名为 “cortex” 的插件包claude plugin install cortexalexander-danilenko这里的cortex是插件包在源内的标识名alexander-danilenko指定了从哪个市场源安装。安装过程会拉取技能定义文件到本地合适的目录通常是~/.claude/plugins/下。步骤 3验证与使用安装完成后重启你的 Claude Code 编辑器如果它正在运行。现在在 Claude Code 的聊天输入框中输入/你应该能看到一个自动补全列表其中包含了来自 Cortex AI Skills 的各种技能例如/api-designer。直接选择或输入完整的技能名然后跟上你的具体需求描述AI 就会以该技能定义的上下文来回应你。注意这种方式安装的技能是全局的对所有项目生效。技能更新需要通过claude plugin update cortexalexander-danilenko来手动进行。3.2 方式二通过npx skills工具安装通用性强这种方式更适合希望统一管理多个来源的技能或者在使用 Cursor 等其他编辑器的用户。npx skills是一个基于 Node.js 的工具因此你需要先确保系统已安装 Node.js 和 npm。步骤 1安装全部技能如果你想一次性安装该仓库中的所有技能并应用到 Claude Code 上可以运行npx skills add alexander-danilenko/cortex-ai-skills --skill * --agent claude-code --global --copy让我们拆解这个命令npx skills add调用skills工具的添加命令。alexander-danilenko/cortex-ai-skills指定技能来源的 GitHub 仓库。--skill *通配符*表示安装该仓库下的所有技能。--agent claude-code指定这些技能是为 Claude Code 代理准备的。工具会根据不同代理的要求调整技能的部署格式和位置。--global表示全局安装对所有项目生效。--copy将技能文件复制到代理的配置目录而不是创建符号链接。这通常更稳定避免因源文件移动导致技能失效。步骤 2选择性安装单个技能如果你只需要其中的某个特定技能比如agents-md-pro假设这是一个用于编写智能体规范文档的技能可以运行npx skills add alexander-danilenko/cortex-ai-skills --skill agents-md-pro --agent claude-code --global --copy步骤 3浏览可用技能列表在安装前你可以先查看该仓库提供了哪些技能npx skills add alexander-danilenko/cortex-ai-skills --list这个命令会获取仓库的索引并列出所有可用的技能名称及其简要描述帮助你做出选择。步骤 4安装其他推荐技能项目文档推荐了 Anthropic 官方的技能库其中包含一个非常实用的skill-creator技能它可以帮助你以标准格式创建新的技能。安装它npx skills add anthropics/skills --skill skill-creator --agent claude-code --global --copy安装后你就可以在 Claude Code 中使用/skill-creator命令来引导你创建符合规范的新技能了这对于后续的开发和贡献至关重要。3.3 安装后的验证与常见问题安装完成后如何验证技能是否生效对于 Claude Code重启编辑器输入/查看命令列表。如果能看到新技能即表示成功。对于 Cursor技能集成方式可能略有不同。通常Cursor 的技能或自定义指令需要在其设置界面Settings - Copilot - Custom Instructions中配置或者有特定的技能目录。npx skills工具在指定--agent cursor时会尝试处理这些差异但最好查阅 Cursor 的官方文档确认技能文件的存放位置。常见问题排查技能列表未出现首先确认安装命令是否成功执行无报错。然后检查对应 AI 助手的配置目录。对于 Claude Code技能文件通常位于~/.claude/plugins/或~/.config/claude/下的相关子目录。确认文件已存在。命令执行无效果可能是技能定义文件格式有误或者与当前 AI 助手的版本不兼容。尝试查看 AI 助手的错误日志或开发者控制台。npx命令找不到请确保 Node.js 版本在 12 或以上并且网络通畅。有时首次运行npx会稍有延迟。4. 技能开发与本地调试实战直接使用现成技能固然方便但真正的威力在于根据自己的工作流定制技能。Cortex AI Skills 项目提供了完善的本地开发支持让你可以快速迭代和测试自己的技能。4.1 搭建本地开发环境第一步克隆仓库首先将项目代码克隆到本地git clone https://github.com/alexander-danilenko/cortex-ai-skills.git cd cortex-ai-skills第二步以开发模式加载插件你不需要每次修改都重新安装插件。Claude Code 允许你在启动时临时指定一个插件目录这对于调试来说非常方便claude --plugin-dir /path/to/your/cloned/cortex-ai-skills这条命令会启动 Claude Code并临时加载你指定目录下的插件。此时你在该目录下对技能文件所做的任何修改在重启 Claude Code 后或有时在聊天会话中刷新上下文后就会立即生效。你可以打开两个终端一个运行此命令启动 Claude Code另一个用于编辑技能文件实现边改边测。4.2 创建持久化的本地技能市场临时加载适合快速测试但如果你希望本地修改的技能能像正式安装的插件一样持久可用就需要将其注册为一个本地市场。步骤 1编辑 Claude Code 设置文件找到 Claude Code 的全局设置文件通常位于~/.claude/settings.json。如果文件不存在可以手动创建。在该文件中添加或修改extraKnownMarketplaces配置项{ extraKnownMarketplaces: { local: { source: { source: directory, path: /absolute/path/to/your/cloned/cortex-ai-skills } } } }关键点local这是你为这个本地市场起的名字可以自定义比如叫my-dev-skills。path必须使用绝对路径不能使用~或相对路径。步骤 2从本地市场安装保存设置文件后你就可以像从远程市场安装一样从你的本地市场安装插件了claude plugin install cortexlocal这里的cortex是仓库内定义的插件包名local指定从你刚配置的名为local的市场安装。步骤 3享受无缝更新从此以后当你对本地仓库的技能文件进行修改后只需要在终端执行更新命令claude plugin update cortexlocalClaude Code 会识别出本地文件的变化并更新插件。你通常需要重启 Claude Code 的聊天会话或完全重启编辑器来让新技能生效。这种方式完美结合了开发的灵活性和使用的便利性。4.3 技能文件结构与创建规范一个技能通常由一个目录或一个文件构成。以 Claude Code 技能为例一个标准的技能文件可能是一个.md文件其结构遵循特定的 Frontmatter元数据和内容格式。一个简化的技能文件示例 (my-skill.md)--- name: Code Reviewer Pro description: 扮演资深代码审查员严格检查代码质量、安全性和最佳实践。 author: YourName tags: [code-review, security, best-practices] version: 1.0.0 --- # 角色资深代码审查员 ## 核心职责 你是一名经验丰富的软件工程师专注于代码审查。你的目标是帮助开发者提升代码质量发现潜在缺陷并推广最佳实践。 ## 审查流程 1. **功能性**代码是否实现了既定需求是否存在逻辑错误 2. **可读性**命名是否清晰结构是否合理注释是否恰当 3. **安全性**是否存在注入、硬编码密钥、不安全的依赖等风险 4. **性能**是否存在低效算法、不必要的循环或内存泄漏风险 5. **可维护性**是否符合项目代码规范模块化程度如何 ## 输出格式 请按以下结构提供审查反馈 - **总体评价**简要总结 - **关键问题**按严重性列出每个问题附带代码行号和具体建议 - **改进建议**具体的代码修改示例 - **潜在优化**非必须但能提升代码质量的建议 ## 约束 - 反馈需具体、可操作避免空泛批评。 - 对事不对人语气专业且友好。 - 优先处理阻塞性和高风险问题。关键组成部分解析Frontmatter (---内)这是技能的元数据AI 助手和工具靠它来识别、分类和管理技能。name,description是必填项。内容部分这是技能的核心即 AI 执行任务时所遵循的“剧本”。它定义了 AI 的角色、任务步骤、输出格式和约束条件。写得越清晰、越结构化AI 的执行效果就越好。创建技能的最佳实践使用skill-creator强烈建议先安装并使用前文提到的官方skill-creator技能。它能通过交互式问答帮你生成一个符合所有格式要求的技能文件骨架避免因格式错误导致技能失效。单一职责一个技能最好只做一件事并把它做到极致。不要创建“万能代码助手”这样的技能而是拆分成“API 设计器”、“数据库迁移脚本生成器”、“单元测试编写器”等具体技能。提供示例在技能描述中如果可能包含一个输入输出的示例。这能极大地帮助 AI 理解你的预期。迭代优化技能不是一次写成的。在实际使用中你可能会发现 AI 的响应有时会偏离预期。这时你需要回到技能定义中调整提示词的表述增加更明确的约束或者优化任务步骤。这是一个持续的调优过程。5. 实战构建一个属于自己的实用技能让我们脱离理论亲手构建一个能解决实际问题的技能。假设我经常需要将一段复杂的业务逻辑用 Mermaid 时序图表示出来以便在技术文档中说明。手动绘制和调整这种图很耗时我们可以创建一个mermaid-sequence技能。5.1 技能规划与设计目标用户提供一段文字描述例如“用户登录时前端发送请求到网关网关调用认证服务认证服务查询数据库后返回结果网关再响应前端”技能能引导 AI 生成对应的、语法正确的 Mermaid 时序图代码。设计思路角色设定让 AI 扮演一个“软件架构可视化专家”。任务分解引导 AI 先理解文本中的参与者和交互顺序再将其转化为 Mermaid 标准语法。输出约束必须输出纯净的 Mermaid 代码块方便用户直接复制到支持 Mermaid 的 Markdown 编辑器中渲染。错误处理要求 AI 如果遇到歧义先提出澄清问题而不是猜测。5.2 技能文件编写我们可以利用/skill-creator来启动或者手动创建文件skills/mermaid-sequence.md。--- name: Mermaid Sequence Diagram Generator description: 将自然语言描述的系统交互流程转化为标准的 Mermaid 时序图代码。 author: [你的名字] tags: [documentation, diagram, mermaid, sequence] version: 1.0.0 --- # 角色软件架构可视化专家 你擅长将复杂的系统交互流程清晰、准确地可视化为时序图。你的任务是理解用户用自然语言描述的过程并输出语法正确、可直接使用的 Mermaid 时序图代码。 ## 工作流程 1. **解析输入**仔细阅读用户提供的描述。识别出所有参与交互的“参与者”如用户、前端、后端服务、数据库、第三方API等。 2. **梳理时序**确定交互发生的先后顺序。注意并发、循环、条件判断等复杂逻辑。 3. **澄清歧义**如果描述中存在模糊、矛盾或缺失的信息例如某个参与者的名称不统一或某个步骤的结果不明确**必须首先向用户提问以澄清**而不是自行假设。 4. **生成代码**基于明确的信息使用 Mermaid 的 sequenceDiagram 语法生成代码。确保 - 参与者声明规范。 - 消息箭头-, --, -, --- 等使用恰当能区分同步/异步、请求/响应。 - 包含必要的注释Note over来标注关键步骤。 - 激活框activate/deactivate使用得当以清晰表示控制焦点。 5. **输出格式**将最终代码包裹在 mermaid 代码块中。在代码块前用一两句话简要说明图表的结构。 ## 输出示例 **用户输入**“客户端调用API服务AA服务同时调用B服务和C服务等两者都返回后A聚合结果返回给客户端。” **你的输出** 我识别出四个参与者Client, ServiceA, ServiceB, ServiceC。交互是并行的。以下是生成的时序图代码 mermaid sequenceDiagram participant C as Client participant A as ServiceA participant B as ServiceB participant C2 as ServiceC C-A: 请求 activate A par 并行调用 A-B: 子请求1 activate B B--A: 响应1 deactivate B and A-C2: 子请求2 activate C2 C2--A: 响应2 deactivate C2 end A--C: 聚合响应 deactivate A约束条件绝不猜测。如有不确定务必先提问。生成的代码必须能通过 Mermaid 解析器的语法检查。优先保持图表简洁易懂避免过度装饰。如果用户描述过于简单可以建议补充信息以生成更详细的图。### 5.3 技能测试与迭代 将写好的技能文件放入本地仓库的 skills/ 目录下。然后按照前面“本地开发环境”一节的方法让 Claude Code 加载你的本地插件目录。 在 Claude Code 中输入 /mermaid-sequence然后粘贴一段测试描述例如“用户访问首页加载静态资源然后前端调用用户信息接口后端校验令牌后从缓存获取信息返回。” 观察 AI 的响应。第一次可能不完美比如它可能没有使用 par 来表示并行或者参与者命名不够清晰。这时你需要回到技能文件中修改“工作流程”或“约束条件”部分。例如在“工作流程”第4点中更强调“注意识别并行步骤并使用 par...end 语法”。经过2-3轮这样的“使用-发现问题-修改技能定义-再测试”的循环你就能打磨出一个非常可靠、符合你预期的技能。 这个实战过程清晰地展示了技能开发的本质**你不是在编程而是在“教育”AI为它编写一份极其详尽、无歧义的“工作说明书”**。技能的质量直接取决于这份说明书的清晰度和完整性。 ## 6. 技能管理与维护进阶技巧 当你积累的技能越来越多有效的管理就变得重要了。以下是一些进阶的实践心得 **1. 技能分类与命名规范** - **分类**可以在技能名称或标签tags上体现分类例如 db/ 前缀表示数据库相关技能 (db/migration-generator) api/ 前缀表示 API 相关技能 (api/openapi-spec)。这在你拥有几十个技能时能帮助你快速定位。 - **命名**技能名最好采用 kebab-case短横线连接且能直观反映功能如 generate-unit-test 就比 testHelper 更清晰。 **2. 版本控制与变更日志** 虽然技能文件是简单的文本但将其纳入 Git 版本控制是必须的。建议为每个技能文件在 Frontmatter 中维护一个 version 字段。当你对技能做出重大改进或修复时递增版本号并在提交信息或仓库的 CHANGELOG 中简要说明变更内容。这对于团队共享技能或回滚到旧版本非常有帮助。 **3. 技能组合与串联** 高级用法是技能间的组合。例如你可以先使用 /code-analyzer 技能分析一段代码的逻辑然后将分析结果作为输入再用 /documentation-writer 技能来生成函数注释或模块文档。虽然目前大多数 AI 助手不支持直接的技能管道pipeline调用但你可以通过手动复制输出来实现这种串联这能极大提升复杂任务的完成效率。 **4. 性能与成本考量** 复杂的技能可能包含非常长的提示词这会在每次调用时消耗更多的 TokenAI 计算的计价单位。虽然对于 Claude Code 等工具的日常使用影响不大但如果你构建的技能是给一个通过 API 调用的 AI 应用使用就需要考虑提示词长度对延迟和成本的影响。优化技巧包括精简不必要的描述性语言将固定的示例移到技能文件末尾或作为可选的参考使用更精确的术语。 **5. 分享与协作** Cortex AI Skills 项目本身就是一个很好的范例。你可以将自己的技能库开源或者在公司内部建立共享的技能仓库。使用 npx skills 工具团队成员可以轻松地从内部 Git 仓库安装技能确保团队内部代码审查、文档编写等标准的一致性。 ## 7. 常见问题与深度排查指南 在实际使用和开发技能的过程中你可能会遇到一些棘手的问题。以下是我总结的一些常见情况及解决方案。 **问题 1技能安装成功但在 AI 助手中看不到或无法调用。** - **可能原因 A技能文件格式错误。** - **排查**检查技能文件的 Frontmatter 格式是否正确YAML 格式以 --- 包裹。确保没有语法错误如缺少冒号、缩进使用了 Tab 键等。一个快速的验证方法是使用在线的 YAML 解析器检查 Frontmatter 部分。 - **解决**严格按照 skill-creator 生成的模板来编写或参考仓库中其他正常工作的技能文件。 - **可能原因 B技能存放路径不正确。** - **排查**不同的 AI 助手和安装工具技能存放的路径不同。对于通过 npx skills 安装到 Claude Code 的技能可以去 ~/.config/claude/skills/macOS/Linux或 %APPDATA%\claude\skills\Windows下查看文件是否存在。 - **解决**确认安装命令中指定的 --agent 参数正确并查阅对应工具的文档确认安装路径。 - **可能原因 CAI 助手需要刷新或重启。** - **排查**某些编辑器特别是 Cursor可能需要完全重启才能加载新安装的技能。Claude Code 有时也需要重启聊天会话。 - **解决**尝试完全退出并重新启动你的 AI 编码助手应用。 **问题 2技能可以调用但 AI 的响应不符合预期或忽略了技能中的关键指令。** - **可能原因 A提示词技能内容存在歧义或冲突。** - **排查**这是最常见的原因。仔细阅读你的技能描述是否存在相互矛盾的指令例如既要求“输出简洁”又要求“列出所有细节”。AI 可能会困惑。 - **解决**重构你的技能描述确保指令清晰、有序、无矛盾。使用明确的编号步骤并强调优先级。例如“首先必须做 X。然后在 X 的基础上进行 Y。最后输出格式必须严格遵守 Z。” - **可能原因 B用户输入与技能预设的上下文不匹配。** - **排查**技能可能预设了处理“代码块”但用户输入的是纯文本描述导致 AI 不知道如何处理。 - **解决**在技能描述中明确输入格式。例如“请提供你想要分析的代码片段。”或者“请用自然语言描述你的需求。” 你甚至可以在技能中增加一个“输入验证”步骤让 AI 在发现输入不符合预期时主动要求用户调整。 - **可能原因 C技能过于复杂超出了 AI 的单次上下文处理能力。** - **排查**如果你的技能文件非常长例如超过几千字AI 可能在处理后续指令时“忘记”了开头的约束。 - **解决**尝试拆分技能。将一个庞大的“全能设计技能”拆分成“需求分析技能”、“架构图技能”、“API 设计技能”等几个更专注的技能然后引导用户分步使用。 **问题 3在团队中共享技能时其他人的环境无法正常工作。** - **可能原因 A路径或依赖问题。** - **排查**你的技能中是否硬编码了本地绝对路径例如引用了一个本地模板文件或者依赖了某个特定版本的外部工具 - **解决**技能应尽量自包含。如果需要外部资源考虑将其内容以字符串形式嵌入到技能描述中或者提供明确的下载/配置说明。使用相对路径或环境变量。 - **可能原因 BAI 助手版本或配置差异。** - **排查**团队成员的 Claude Code 或 Cursor 版本可能不同对技能的支持度有差异。 - **解决**在技能仓库的 README 中明确说明测试通过的 AI 助手及其最低版本号。鼓励团队使用相近的版本。 **问题 4使用 npx skills 管理多个来源的技能时发生冲突。** - **可能原因技能名称重复。** - **排查**从仓库 A 安装了名为 code-review 的技能又从仓库 B 安装了同名的技能后者可能会覆盖前者。 - **解决**npx skills 工具通常会有冲突处理机制但最好从源头避免。在创建自己的技能时使用带有个人或组织前缀的命名如 myteam-code-review。在安装时也可以使用 --prefix 参数如果工具支持来为技能名添加命名空间。 开发和使用 AI 技能库是一个不断探索和优化的过程。从解决一个具体的重复性任务开始逐步积累和完善你的技能工具箱你会发现 AI 编码助手从一个“聪明的聊天伙伴”真正转变为你工作流中一个强大而顺手的“自动化组件”。Cortex AI Skills 项目为你展示了这条路径的起点剩下的就取决于你如何将你的专业经验转化为 AI 能理解和执行的精确指令了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2583186.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;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…