02_context_builder_with_agent.py 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. """
  2. ContextBuilder 与 Agent 集成示例
  3. 展示如何将 ContextBuilder 集成到 Agent 中,实现:
  4. 1. 上下文感知的 Agent
  5. 2. 自动构建优化的上下文
  6. 3. 记忆管理与上下文构建的协同
  7. """
  8. from hello_agents import SimpleAgent, HelloAgentsLLM, ToolRegistry
  9. from hello_agents.context import ContextBuilder, ContextConfig
  10. from hello_agents.tools import MemoryTool, RAGTool
  11. from hello_agents.core.message import Message
  12. from datetime import datetime
  13. class ContextAwareAgent(SimpleAgent):
  14. """具有上下文感知能力的 Agent"""
  15. def __init__(self, name: str, llm: HelloAgentsLLM, **kwargs):
  16. super().__init__(name=name, llm=llm, **kwargs)
  17. # 初始化上下文构建器
  18. self.memory_tool = MemoryTool(user_id=kwargs.get("user_id", "default"))
  19. self.rag_tool = RAGTool(knowledge_base_path=kwargs.get("knowledge_base_path", "./kb"))
  20. self.context_builder = ContextBuilder(
  21. memory_tool=self.memory_tool,
  22. rag_tool=self.rag_tool,
  23. config=ContextConfig(max_tokens=4000)
  24. )
  25. self.conversation_history = []
  26. def run(self, user_input: str) -> str:
  27. """运行 Agent,自动构建优化的上下文"""
  28. # 1. 使用 ContextBuilder 构建优化的上下文
  29. optimized_context = self.context_builder.build(
  30. user_query=user_input,
  31. conversation_history=self.conversation_history,
  32. system_instructions=self.system_prompt
  33. )
  34. # 2. 使用优化后的上下文调用 LLM
  35. response = self.llm.invoke(optimized_context)
  36. # 3. 更新对话历史
  37. self.conversation_history.append(
  38. Message(content=user_input, role="user", timestamp=datetime.now())
  39. )
  40. self.conversation_history.append(
  41. Message(content=response, role="assistant", timestamp=datetime.now())
  42. )
  43. # 4. 将重要交互记录到记忆系统
  44. self.memory_tool.execute(
  45. "add",
  46. content=f"Q: {user_input}\nA: {response[:200]}...", # 摘要
  47. memory_type="episodic",
  48. importance=0.6
  49. )
  50. return response
  51. def main():
  52. print("=" * 80)
  53. print("ContextBuilder 与 Agent 集成示例")
  54. print("=" * 80 + "\n")
  55. # 配置 LLM
  56. from hello_agents.core.llm import HelloAgentsLLM
  57. llm = HelloAgentsLLM(
  58. model="ZhipuAI/GLM-4.6",
  59. api_key="6ff5219e-410a-4293-8772-0c948bfa691c",
  60. base_url="https://api-inference.modelscope.cn/v1/",
  61. provider="modelscope"
  62. )
  63. # 使用示例
  64. agent = ContextAwareAgent(
  65. name="数据分析顾问",
  66. llm=llm,
  67. user_id="user123",
  68. knowledge_base_path="./data_science_kb",
  69. system_prompt="你是一位资深的Python数据工程顾问。"
  70. )
  71. # 进行对话
  72. response = agent.run("如何优化Pandas的内存占用?")
  73. print(f"助手回答:\n{response}\n")
  74. # 继续对话
  75. response = agent.run("能给出具体的代码示例吗?")
  76. print(f"助手回答:\n{response}\n")
  77. print("=" * 80)
  78. if __name__ == "__main__":
  79. main()