| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- from hello_agents import SimpleAgent, HelloAgentsLLM
- from hello_agents.tools import Tool
- from typing import List
- class ReviewerAgent(SimpleAgent):
- """
- 负责评审代码的智能体。
- 它可以访问 CodeRunner 工具来执行代码。
- """
-
- def __init__(self, llm: HelloAgentsLLM, tools: List[Tool] = None, knowledge_service=None):
- """
- 初始化 ReviewerAgent。
-
- Args:
- llm: 用于评审代码的大语言模型实例。
- tools: 智能体可用的工具列表(例如 CodeRunner)。
- """
- system_prompt = """
- 你是一位细致的编程代码评审员。
- 你的目标是分析用户代码的正确性、风格和效率。
-
- 你配备了一个 'code_runner' 工具,可以用来执行 Python 代码。
-
- **重要:代码形式识别**
- - 代码片段(Code Snippet):可以直接运行的简短代码,如变量赋值、简单计算等
- - 函数定义(Function):以 def 开头,包含函数体的完整代码
- - 不完整代码:缺少必要的语法元素(如未闭合的括号、缺少 return 等)
-
- **评审流程**:
- 1. **识别代码类型**:判断是代码片段还是函数定义
- 2. **运行代码**(推荐):使用 'code_runner' 工具执行代码,验证是否能正常运行
- 3. **分析逻辑**:检查代码逻辑是否正确,是否达到预期目标
- 4. **检查风格**:评估代码风格(变量命名、PEP8规范)
- 5. **性能分析**:提出优化建议(时间/空间复杂度)
- 6. **建设性反馈**:指出优点和改进空间
-
- **评审原则**:
- - ✅ 如果代码可以正常运行,不要说它"不完整"
- - ✅ 针对实际代码逻辑进行评审,而不是臆测用户意图
- - ✅ 区分"代码片段"和"需要函数封装"的建议
- - ✅ 先肯定做得好的地方,再提出改进建议
-
- 如果代码有错误,解释原因并提供修复提示,但不要直接给出完整的解决方案,除非用户多次尝试失败。
- """
- self.knowledge = knowledge_service
- super().__init__(
- name="Reviewer",
- llm=llm,
- system_prompt=system_prompt
- )
-
- if tools:
- for tool in tools:
- self.add_tool(tool)
- def run(self, input_text: str, max_tool_iterations: int = 3, **kwargs) -> str:
- result = super().run(input_text, max_tool_iterations, **kwargs)
- self.knowledge.add_note(
- content=f"代码评审结论:{result}",
- concept="code_review"
- )
- return result
|