基于Claude API的智能代理框架:从对话到执行的AI应用开发实践

news2026/5/1 4:25:23
1. 项目概述一个为Claude API设计的智能代理框架最近在折腾AI应用开发特别是围绕Anthropic的Claude API构建一些自动化工作流时发现了一个挺有意思的开源项目——openclaw-claude-delegate。这个项目本质上是一个为Claude设计的“智能代理”或“委托执行”框架。简单来说它能让Claude模型不仅限于聊天对话而是能够根据你的指令去调用外部工具、执行代码、查询数据甚至控制其他软件完成一系列复杂的、多步骤的任务。想象一下你不再需要手动复制粘贴Claude的回答然后自己去执行它建议的操作。你可以直接告诉Claude“帮我分析一下这个CSV文件找出销售额最高的产品然后生成一份总结报告并发送到我的邮箱。” 通过openclaw-claude-delegateClaude可以理解这个复杂指令分解成“读取文件”、“数据分析”、“生成报告”、“调用邮件API”等多个子任务并自动协调执行。这大大提升了AI的实用性和生产力将对话模型变成了一个能“动手”的智能助手。这个项目由开发者StoicEnso维护从名字就能看出其野心——“Open Claw”开放的爪子寓意着为Claude赋予抓取和操作外部世界的能力。它非常适合那些希望将Claude深度集成到自家产品、自动化脚本或研究项目中的开发者。无论是构建一个智能客服机器人、一个数据分析助手还是一个自动化办公流程这个框架都提供了一个清晰、可扩展的起点。接下来我就结合自己的使用和探索经验来深度拆解一下这个项目的设计思路、核心实现以及如何上手应用。2. 核心架构与设计哲学解析2.1 从“聊天”到“行动”智能代理的核心范式转变传统的语言模型交互停留在“一问一答”的文本生成层面。用户提问模型回答无论答案多么详尽最终的执行权仍在用户手中。openclaw-claude-delegate引入的“委托代理”模式核心是赋予模型“行动力”。其设计哲学建立在几个关键认知之上首先大语言模型LLM是优秀的规划者和决策者但不是好的执行者。Claude可以完美地理解“请查询北京明天天气如果下雨就提醒我带伞”这个指令并分解出“查询天气API”和“条件判断”两个步骤。但它自身无法调用天气API。框架的作用就是充当模型的“手和脚”提供一套标准化的方式让模型能安全、可控地指挥这些“手脚”去工作。其次安全与可控性是第一生命线。让一个AI模型去执行代码或访问网络听起来就充满风险。因此框架在设计上必须包含严格的权限控制、操作确认机制尤其是在涉及敏感操作时以及清晰的执行边界。openclaw-claude-delegate通常通过“工具Tools”的概念来实现这一点。开发者需要明确定义Claude可以调用哪些工具每个工具能做什么、输入输出格式是什么并且可以在工具执行前加入人工确认或自动安全检查。最后状态管理与上下文保持是复杂任务的关键。一个多步骤任务可能涉及多次模型调用和工具执行。框架需要妥善管理整个对话和工作流的状态确保Claude在每一步都拥有足够的上下文信息来做决策。比如在“分析数据并生成图表”的任务中Claude调用工具读取数据后需要记住这些数据的内容才能在下一步指导图表生成工具。2.2 框架的核心组件与工作流基于以上哲学openclaw-claude-delegate的架构通常会围绕以下几个核心组件展开代理Agent这是框架的核心大脑通常是一个封装了Claude API调用逻辑的模块。它负责接收用户指令与Claude模型进行多轮对话并根据模型的“思考”决定下一步是生成回复给用户还是调用某个工具。工具Tools这是框架的“肌肉”。每个工具代表一个可执行的动作比如execute_python执行Python代码、search_web网络搜索、read_file读取文件等。工具需要被精确地定义包括名称、描述、参数列表及其类型和说明。当Claude决定使用工具时它会按照预定格式输出一个结构化的调用请求。工具执行器Tool Executor负责接收来自Agent的工具调用请求找到对应的工具实现传入参数执行它并捕获执行结果或错误。这个组件是安全控制的关键节点可以在这里加入沙箱环境对于代码执行、超时控制、权限验证等。工作流引擎/状态管理器Workflow Engine / State Manager负责维护整个会话的状态。这包括完整的对话历史、已执行工具的结果序列、当前的任务目标等。它确保每一次Agent与Claude的交互都是基于最新、最全的上下文。记忆Memory对于长对话或复杂任务可能需要将关键信息持久化或进行总结提炼。记忆模块负责处理这部分可以是简单的对话历史缓存也可以是更复杂的向量数据库存储用于长期记忆和相关信息检索。一个典型的工作流如下步骤1用户输入指令“总结一下https://example.com/page的内容”。步骤2Agent将指令和当前上下文可能是空的发送给Claude。步骤3Claude“思考”后发现需要调用fetch_webpage工具来获取网页内容。于是它输出一个结构化消息如{action: call_tool, tool_name: fetch_webpage, arguments: {url: https://example.com/page}}。步骤4Agent解析该消息将调用请求交给Tool Executor。步骤5Tool Executor执行fetch_webpage工具获取到网页的HTML文本。步骤6Agent将工具执行结果网页内容作为新的上下文信息再次发送给Claude。步骤7Claude接收到网页内容后现在可以执行总结任务并生成最终答案输出给用户。这个过程可能会循环多次直到任务完成。框架的价值就在于自动化、可靠地管理这个循环。3. 关键技术与实现细节剖析3.1 与Claude API的深度集成超越简单聊天openclaw-claude-delegate与Claude API的集成远不止是发送一个POST请求那么简单。它需要充分利用Claude模型的高级特性特别是其强大的系统提示词System Prompt能力和对结构化输出的支持。系统提示词System Prompt的精心设计这是“教导”Claude如何扮演一个代理角色的关键。一个优秀的系统提示词需要明确告诉Claude你的角色是什么例如“你是一个能够使用工具来完成用户请求的AI助手。”你可以使用哪些工具每个工具是干什么的参数格式是什么你输出的格式必须是什么例如当想调用工具时必须严格以TOOL_CALL:开头后跟JSON。你的思考过程应该如何鼓励链式思考先分析任务再决定是否用工具。安全准则是什么例如不能执行危险代码涉及用户数据需确认。项目源码中通常会有一个精心打磨的系统提示词模板这是整个项目智能水平的基石。结构化输出与函数调用虽然Claude API原生支持类似OpenAI的“函数调用”Function Calling功能但openclaw-claude-delegate可能需要处理更灵活或更早版本的API。因此一种常见的实现方式是引导模型输出特定格式的文本然后通过正则表达式或解析器来提取工具调用信息。这要求模型有极高的指令遵循能力。另一种更现代的方式是利用Claude API的tools参数直接传入工具定义让API返回结构化的工具调用请求。框架需要兼容这两种模式并提供稳定的解析逻辑。上下文窗口管理与优化Claude拥有巨大的上下文窗口如200K tokens但工具执行的结果如一整份网页内容或数据集可能非常冗长。盲目地将所有历史对话和工具结果都塞进上下文会快速消耗tokens并增加成本、降低速度。因此框架需要实现智能的上下文管理策略例如选择性摘要对长的工具执行结果进行摘要后再喂给模型。历史截断与滚动只保留最近N轮对话和最相关的工具结果。外部记忆将不急需的上下文存入向量数据库需要时通过检索增强生成RAG的方式召回。3.2 工具系统的设计与扩展工具系统是框架可扩展性的核心。一个设计良好的工具系统应该满足声明式定义工具应该能用一种清晰、简洁的方式声明。例如使用Python的装饰器或Pydantic模型tool def search_web(query: str, max_results: int 5) - str: 使用搜索引擎查询网络信息。 Args: query: 搜索关键词。 max_results: 返回的最大结果数默认为5。 Returns: 返回搜索结果的格式化文本摘要。 # ... 实现搜索逻辑 ... return formatted_results框架会自动从函数签名和文档字符串中提取工具的名称、描述和参数schema供Claude理解。安全性隔离这是重中之重。对于执行代码exec、eval或访问系统文件/网络这类高风险工具必须放在沙箱环境中运行。Docker容器是一个常见选择但重量较重一些轻量级沙箱如pysandbox或严格的资源限制resource模块也可考虑。框架需要提供配置选项让开发者决定每个工具的安全等级。异步与并发执行有些任务可以并行。例如Claude可能同时需要查询天气和股票信息。框架应支持工具的异步执行以提高复杂工作流的效率。这涉及到更复杂的任务编排和结果收集逻辑。自定义工具开发框架的魅力在于开发者可以轻松添加自己的工具。文档应提供清晰的指南说明如何从零创建一个新工具如何测试它以及如何将其集成到工具库中。一个常见的目录结构可能是tools/ ├── __init__.py ├── base.py # 工具基类 ├── web.py # 网络相关工具 ├── code.py # 代码执行工具 ├── file.py # 文件操作工具 └── custom/ # 用户自定义工具目录 └── my_tool.py3.3 状态管理、记忆与持久化对于一次性的简单指令状态管理可能不重要。但对于交互式会话或需要长时间运行的任务如“监控这个日志文件发现错误就通知我”状态持久化至关重要。会话状态Session State框架需要为每个用户或每个对话线程维护一个独立的状态对象。这个对象存储conversation_history: 用户、助手、工具交互的消息列表。variables: 任务执行过程中产生的中间变量例如从网页抓取的数据。task_stack: 如果支持子任务分解可能需要一个任务栈来管理层次结构。记忆Memory的实现可以分为短期记忆和长期记忆。短期记忆就是当前的会话状态保存在内存中。对于Web应用需要与会话Session绑定。长期记忆可以引入向量数据库如Chroma、Weaviate。将对话中的关键实体、结论或工具执行的重要结果转换成向量存储起来。当后续对话涉及相关话题时可以通过检索RAG将这些记忆重新注入上下文让Claude拥有“记忆力”。例如用户上周说过“我喜欢用Markdown记笔记”当本周用户说“把刚才的总结保存一下”时框架可以通过检索回忆起用户的偏好从而调用生成Markdown文件的工具。持久化存储为了服务重启后不丢失状态需要将会话状态序列化如用JSON或Pickle保存到数据库SQLite/PostgreSQL或文件系统中。框架应提供可插拔的存储后端接口。4. 实战部署与应用场景构建4.1 从零开始环境搭建与快速启动假设我们想在本地快速体验openclaw-claude-delegate。虽然项目具体细节可能随时间变化但通用步骤如下第一步环境准备确保你的系统有Python 3.8和pip。强烈建议使用虚拟环境venv或conda来隔离依赖。# 创建并激活虚拟环境 python -m venv openclaw-env source openclaw-env/bin/activate # Linux/macOS # openclaw-env\Scripts\activate # Windows # 克隆项目仓库假设仓库地址 git clone https://github.com/StoicEnso/openclaw-claude-delegate.git cd openclaw-claude-delegate第二步安装依赖查看项目根目录的requirements.txt或pyproject.toml文件安装所有依赖。pip install -r requirements.txt通常依赖会包括anthropic(Claude官方SDK),pydantic(数据验证),httpx或requests(HTTP客户端),python-dotenv(环境变量管理)等。第三步配置API密钥你需要一个Anthropic的API密钥。在项目根目录创建.env文件ANTHROPIC_API_KEYyour_anthropic_api_key_here在代码中通过os.getenv(ANTHROPIC_API_KEY)来读取。务必确保.env文件被添加到.gitignore中切勿提交密钥第四步运行示例项目通常会提供一个简单的示例脚本比如examples/basic_agent.py。运行它来测试连接和基本功能。python examples/basic_agent.py如果一切正常你应该能看到Claude接收指令、调用工具如果有、并返回结果的完整流程在终端中打印出来。注意初次运行可能会失败常见原因是依赖版本冲突或缺少系统库。仔细阅读错误信息按照提示安装缺失的包如apt-get install某些系统库。建议优先使用项目锁定的依赖版本如果有poetry.lock或pipenv文件。4.2 核心配置详解与个性化定制要让框架真正为你所用必须理解其核心配置项。通常配置会通过一个配置文件如config.yaml或Python类来集中管理。模型选择与参数调优claude: model: claude-3-opus-20240229 # 或 claude-3-sonnet, claude-3-haiku temperature: 0.2 # 较低的温度使输出更确定适合工具调用 max_tokens: 4096模型选择Opus能力最强但最贵最慢适合复杂推理Sonnet平衡性好Haiku最快最便宜适合简单任务。根据你的任务复杂度和预算选择。Temperature工具调用要求高精度通常设置较低的值0.1-0.3以减少模型输出的随机性确保工具调用格式的稳定。Max Tokens限制单次回复长度。对于需要调用工具的场景要留出足够空间让模型输出结构化指令。工具配置与权限管理tools: enabled: - web_search - python_executor - file_reader disabled: - system_shell # 高风险工具默认禁用 sandbox: python_executor: enabled: true timeout: 30 # 代码执行超时时间秒 allow_network: false # 是否允许代码访问网络这里可以精细控制每个工具的开关和安全策略。对于python_executor这类工具启用沙箱并限制超时和网络访问是基本安全措施。工作流与Agent配置agent: max_iterations: 10 # 防止死循环限制最大工具调用轮次 require_confirmation_for: [file_writer, send_email] # 高风险操作需用户确认 memory: type: vector # simple 或 vector vector_db_path: ./data/chroma_dbmax_iterations是防止AI陷入无限思考-调用循环的重要保险丝。require_confirmation_for列表中的工具在执行前会向用户或一个确认接口发起请求得到确认后才执行。这是实现“人在环路”Human-in-the-loop控制的关键。memory配置决定了记忆模块的类型向量记忆能提供更智能的上下文关联。4.3 构建你的第一个自定义智能代理现在让我们动手创建一个能解决实际问题的代理。假设我们想创建一个“技术文档助手”它能根据我的问题搜索网络用DuckDuckGo并总结答案。第一步创建自定义工具我们先创建一个网络搜索工具。在tools/custom/目录下创建duckduckgo_search.py# tools/custom/duckduckgo_search.py import requests from typing import Optional from .base import BaseTool # 假设有一个基础工具类 from pydantic import Field class DuckDuckGoSearchTool(BaseTool): 一个使用DuckDuckGo Instant Answer API进行搜索的工具。 name duckduckgo_search description 搜索网络获取最新信息。适用于查询事实、定义、最新消息等。 class ArgsSchema(BaseTool.ArgsSchema): query: str Field(..., description要搜索的关键词或问题。) max_results: Optional[int] Field(5, description返回的摘要结果数量默认为5。) async def execute(self, query: str, max_results: int 5) - str: 执行搜索并返回格式化结果。 # 注意DuckDuckGo Instant Answer API是简单示例实际可用更强大的SerpAPI等。 url https://api.duckduckgo.com/ params { q: query, format: json, no_html: 1, skip_disambig: 1, } try: response requests.get(url, paramsparams, timeout10) data response.json() # 提取摘要文本 abstract data.get(AbstractText, ) if abstract: result f摘要{abstract}\n else: result 未找到直接摘要。\n # 提取相关主题 related_topics data.get(RelatedTopics, []) for i, topic in enumerate(related_topics[:max_results]): if isinstance(topic, dict) and Text in topic: result f{i1}. {topic[Text]}\n return result if result.strip() else 未找到相关信息。 except Exception as e: return f搜索过程中出错{str(e)}第二步注册工具在工具加载的入口文件如tools/__init__.py中导入并注册你的新工具# tools/__init__.py from .custom.duckduckgo_search import DuckDuckGoSearchTool # 在工具字典中注册 ALL_TOOLS { # ... 其他内置工具 ... duckduckgo_search: DuckDuckGoSearchTool(), }第三步编写代理运行脚本创建一个新的脚本my_doc_assistant.py# my_doc_assistant.py import asyncio import sys from openclaw_core.agent import Agent # 假设框架的主Agent类 from openclaw_core.config import load_config async def main(): # 1. 加载配置 config load_config(config.yaml) # 2. 创建Agent实例传入配置和启用的工具列表 agent Agent( configconfig, enabled_tools[duckduckgo_search, python_executor] # 启用搜索和Python工具 ) # 3. 与代理交互 print(技术文档助手已启动。输入退出或quit结束。) while True: try: user_input input(\n您的问题: ).strip() if user_input.lower() in [退出, quit, exit]: print(再见) break if not user_input: continue # 运行代理 response await agent.run(user_input) print(f\n助手: {response}) except KeyboardInterrupt: print(\n程序被中断。) break except Exception as e: print(f\n运行出错: {e}) if __name__ __main__: asyncio.run(main())第四步运行测试python my_doc_assistant.py尝试提问“Python中asyncio.run()和loop.run_until_complete()有什么区别” 观察代理是否会调用搜索工具并整合信息给出回答。通过这个例子你就能掌握扩展框架的基本流程定义工具 → 注册工具 → 配置代理 → 运行交互。你可以依葫芦画瓢添加更多工具如read_github_readme、query_stackoverflow等打造更强大的专属助手。5. 高级应用、性能优化与避坑指南5.1 复杂工作流编排与多代理协作当单个代理无法处理复杂任务时就需要引入工作流编排。例如一个“市场调研报告生成”任务可能涉及1) 搜索最新行业新闻2) 抓取竞争对手数据3) 进行数据分析4) 生成报告草稿5) 润色文案。这可以分解为多个子任务由不同的“专家”代理协作完成。使用工作流引擎框架可以集成像Prefect或Airflow这样的轻量级工作流引擎或者自己实现一个简单的有向无环图DAG调度器。每个节点是一个代理或一个工具调用节点之间通过数据流连接。# 伪代码示例定义一个简单的工作流 workflow Workflow() workflow.add_node(search_news, NewsSearchAgent()) workflow.add_node(analyze_sentiment, SentimentAnalysisTool()) workflow.add_node(generate_report, ReportWriterAgent()) workflow.add_edge(search_news, analyze_sentiment) # 新闻搜索结果传给情感分析 workflow.add_edge(analyze_sentiment, generate_report) # 分析结果传给报告生成 results await workflow.run(initial_inputAI行业动态)多代理协作模式主从模式一个“主管”代理接收用户任务将其分解并分配给不同的“工作者”代理专门负责搜索、分析、写作等最后汇总结果。辩论模式多个代理对同一问题提出不同方案通过“辩论”最终达成一致或由用户选择。链式模式代理A的输出直接作为代理B的输入形成处理链。实现多代理的关键是设计好代理间的通信协议例如通过共享内存、消息队列或直接函数调用和结果传递格式。5.2 性能优化与成本控制策略使用Claude API和频繁的工具调用性能和成本是需要密切关注的两个方面。性能优化异步与非阻塞确保整个框架特别是网络请求API调用、工具中的HTTP请求和I/O操作都是异步的。使用asyncio和aiohttp/httpx可以极大提升并发能力避免在等待一个工具响应时阻塞整个代理。缓存对于重复性查询或工具调用结果进行缓存。例如对相同的搜索关键词可以缓存搜索结果一段时间。可以使用functools.lru_cache内存缓存或redis作为分布式缓存。批量处理如果可能将多个小的工具调用请求合并。但需注意这需要模型支持批量推理且可能不符合代理的交互逻辑。上下文压缩如前所述对长的历史消息和工具结果进行智能摘要是降低token消耗、提升速度的最有效方法。可以训练一个小模型或使用规则进行摘要。成本控制模型选型在开发、测试和简单任务中使用Haiku模型仅在最终生产或复杂推理时使用Opus。监控与告警集成API使用量监控。记录每次调用的模型、输入/输出token数并设置每日/每周预算告警。Anthropic API仪表板也提供用量查看。失败重试与退避为API调用实现指数退避的重试机制避免因网络抖动导致的失败重复计费。设置硬性限制在代理配置中设置max_tokens_per_session或max_api_calls_per_session等硬性上限防止意外循环导致天价账单。5.3 常见问题排查与实战避坑心得在实际开发和部署openclaw-claude-delegate这类项目时我踩过不少坑这里分享一些典型问题和解决方案问题1Claude不按格式调用工具或者解析失败。原因系统提示词System Prompt对工具调用格式的描述不够清晰、具体或者模型的temperature参数设置过高导致输出不稳定。解决在系统提示词中用非常明确的例子展示工具调用的格式。例如“当你需要搜索时你必须输出ACTION: SEARCH\nQUERY: {你的搜索词}”。将temperature降至0.1或0.2。在代码中增加输出格式的验证和修复逻辑。如果模型输出接近正确格式但有微小偏差如多了一个空格尝试用正则表达式进行容错提取。问题2工具执行陷入无限循环或无关调用。原因模型可能陷入“思考-调用-再思考”的循环或者误解任务调用不相关的工具。解决严格设置max_iterations如10次这是最后的防线。在系统提示词中强调“如果当前信息足以回答问题请直接回答不要调用工具”。优化工具描述使其职责更单一、明确减少歧义。在每次工具调用后让模型进行简短的自评如“这次调用是否必要结果是否相关”这需要额外消耗token。问题3处理复杂、长文本工具结果时上下文爆炸。原因网页抓取、文档读取的结果可能长达数万token直接放入上下文会导致成本剧增且可能超出模型窗口。解决工具端预处理在工具内部进行初步摘要或提取关键信息。例如网页抓取工具可以只返回body中的前N个字符或者使用readability库提取正文。Agent端摘要设计一个“摘要工具”专门用来压缩长文本。当其他工具返回过长结果时Agent可以主动调用摘要工具先进行压缩再将摘要放入上下文。分块处理对于超长文档设计工作流将其分块让模型分多次处理并维护一个全局的摘要或索引。问题4安全性担忧特别是代码执行和文件访问。原因这是代理框架的最大风险点。解决沙箱是必须的代码执行一定要在Docker容器或无网络、无文件系统写入权限的严格沙箱中运行。白名单机制文件访问工具只能访问预先指定的安全目录如/tmp/workspace。用户确认对于文件写入、网络请求非搜索、系统命令等高风险操作强制开启require_confirmation。输入验证与过滤对所有工具的参数进行严格的类型和内容检查过滤掉可能包含恶意命令的字符串。问题5项目依赖复杂部署困难。原因这类项目通常依赖较多且可能涉及系统库。解决使用Docker为项目提供Dockerfile和docker-compose.yml这是保证环境一致性的最佳实践。完善依赖声明使用pyproject.toml配合poetry能更精确地管理依赖和Python版本。提供清晰的部署文档列出所有系统前置依赖如gcc,python3-dev的安装命令。一个实用的调试技巧在开发阶段开启详细的日志记录记录下每一轮Agent与Claude的完整对话、工具调用请求和结果。这能帮助你精准定位是提示词问题、工具解析问题还是工具执行本身的问题。可以将日志级别设为DEBUG并输出到文件方便查看。6. 扩展生态与未来展望openclaw-claude-delegate作为一个框架其生命力很大程度上取决于其工具生态。围绕它可以构建一个丰富的工具市场或社区。工具共享社区开发者可以将自己编写的好用工具如与特定SaaS API集成的工具、专业数据处理工具等打包发布供他人一键安装使用。框架可以定义标准的工具打包、发布和安装协议。可视化编排界面对于不熟悉代码的用户一个图形化的工作流设计器会非常有用。用户可以通过拖拽的方式组合Agent和工具构建自动化流程。这可以作为一个独立的前端应用通过REST API与后端框架交互。与现有生态集成例如将框架封装成LangChain的一个自定义Agent或Toolkit这样就能利用LangChain庞大的现有生态。或者开发插件使其能在FastAPI、Streamlit等Web框架中轻松使用。从更长远看这类智能代理框架正朝着“自主智能体”Autonomous Agent的方向发展。未来的版本可能会集成更强大的规划能力基于LLM的规划器、更复杂的世界模型以及对长期目标的持久追求能力。但无论如何演进安全性、可控性和实用性都将是其不可动摇的基石。对于开发者而言现在深入理解并开始应用这样的框架无疑是站在了AI应用开发的前沿能够亲手打造出真正理解意图并执行任务的数字助手将想象变为现实。

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