autogen_software_team.py 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. """
  2. AutoGen 软件开发团队协作案例
  3. """
  4. import os
  5. import asyncio
  6. from typing import List, Dict, Any
  7. from dotenv import load_dotenv
  8. # 加载环境变量
  9. load_dotenv()
  10. # 先测试一个版本,使用 OpenAI 客户端
  11. from autogen_ext.models.openai import OpenAIChatCompletionClient
  12. from autogen_agentchat.agents import AssistantAgent, UserProxyAgent
  13. from autogen_agentchat.teams import RoundRobinGroupChat
  14. from autogen_agentchat.conditions import TextMentionTermination
  15. from autogen_agentchat.ui import Console
  16. def create_openai_model_client():
  17. """创建 OpenAI 模型客户端用于测试"""
  18. return OpenAIChatCompletionClient(
  19. model=os.getenv("LLM_MODEL_ID", "gpt-4o"),
  20. api_key=os.getenv("LLM_API_KEY"),
  21. base_url=os.getenv("LLM_BASE_URL", "https://api.openai.com/v1")
  22. )
  23. def create_product_manager(model_client):
  24. """创建产品经理智能体"""
  25. system_message = """你是一位经验丰富的产品经理,专门负责软件产品的需求分析和项目规划。
  26. 你的核心职责包括:
  27. 1. **需求分析**:深入理解用户需求,识别核心功能和边界条件
  28. 2. **技术规划**:基于需求制定清晰的技术实现路径
  29. 3. **风险评估**:识别潜在的技术风险和用户体验问题
  30. 4. **协调沟通**:与工程师和其他团队成员进行有效沟通
  31. 当接到开发任务时,请按以下结构进行分析:
  32. 1. 需求理解与分析
  33. 2. 功能模块划分
  34. 3. 技术选型建议
  35. 4. 实现优先级排序
  36. 5. 验收标准定义
  37. 请简洁明了地回应,并在分析完成后说"请工程师开始实现"。"""
  38. return AssistantAgent(
  39. name="ProductManager",
  40. model_client=model_client,
  41. system_message=system_message,
  42. )
  43. def create_engineer(model_client):
  44. """创建软件工程师智能体"""
  45. system_message = """你是一位资深的软件工程师,擅长 Python 开发和 Web 应用构建。
  46. 你的技术专长包括:
  47. 1. **Python 编程**:熟练掌握 Python 语法和最佳实践
  48. 2. **Web 开发**:精通 Streamlit、Flask、Django 等框架
  49. 3. **API 集成**:有丰富的第三方 API 集成经验
  50. 4. **错误处理**:注重代码的健壮性和异常处理
  51. 当收到开发任务时,请:
  52. 1. 仔细分析技术需求
  53. 2. 选择合适的技术方案
  54. 3. 编写完整的代码实现
  55. 4. 添加必要的注释和说明
  56. 5. 考虑边界情况和异常处理
  57. 请提供完整的可运行代码,并在完成后说"请代码审查员检查"。"""
  58. return AssistantAgent(
  59. name="Engineer",
  60. model_client=model_client,
  61. system_message=system_message,
  62. )
  63. def create_code_reviewer(model_client):
  64. """创建代码审查员智能体"""
  65. system_message = """你是一位经验丰富的代码审查专家,专注于代码质量和最佳实践。
  66. 你的审查重点包括:
  67. 1. **代码质量**:检查代码的可读性、可维护性和性能
  68. 2. **安全性**:识别潜在的安全漏洞和风险点
  69. 3. **最佳实践**:确保代码遵循行业标准和最佳实践
  70. 4. **错误处理**:验证异常处理的完整性和合理性
  71. 审查流程:
  72. 1. 仔细阅读和理解代码逻辑
  73. 2. 检查代码规范和最佳实践
  74. 3. 识别潜在问题和改进点
  75. 4. 提供具体的修改建议
  76. 5. 评估代码的整体质量
  77. 请提供具体的审查意见,完成后说"代码审查完成,请用户代理测试"。"""
  78. return AssistantAgent(
  79. name="CodeReviewer",
  80. model_client=model_client,
  81. system_message=system_message,
  82. )
  83. def create_user_proxy():
  84. """创建用户代理智能体"""
  85. return UserProxyAgent(
  86. name="UserProxy",
  87. description="""用户代理,负责以下职责:
  88. 1. 代表用户提出开发需求
  89. 2. 执行最终的代码实现
  90. 3. 验证功能是否符合预期
  91. 4. 提供用户反馈和建议
  92. 完成测试后请回复 TERMINATE。""",
  93. )
  94. async def run_software_development_team():
  95. """运行软件开发团队协作"""
  96. print("🔧 正在初始化模型客户端...")
  97. # 先使用标准的 OpenAI 客户端测试
  98. model_client = create_openai_model_client()
  99. print("👥 正在创建智能体团队...")
  100. # 创建智能体团队
  101. product_manager = create_product_manager(model_client)
  102. engineer = create_engineer(model_client)
  103. code_reviewer = create_code_reviewer(model_client)
  104. user_proxy = create_user_proxy()
  105. # 添加终止条件
  106. termination = TextMentionTermination("TERMINATE")
  107. # 创建团队聊天
  108. team_chat = RoundRobinGroupChat(
  109. participants=[
  110. product_manager,
  111. engineer,
  112. code_reviewer,
  113. user_proxy
  114. ],
  115. termination_condition=termination,
  116. max_turns=20, # 增加最大轮次
  117. )
  118. # 定义开发任务
  119. task = """我们需要开发一个比特币价格显示应用,具体要求如下:
  120. 核心功能:
  121. - 实时显示比特币当前价格(USD)
  122. - 显示24小时价格变化趋势(涨跌幅和涨跌额)
  123. - 提供价格刷新功能
  124. 技术要求:
  125. - 使用 Streamlit 框架创建 Web 应用
  126. - 界面简洁美观,用户友好
  127. - 添加适当的错误处理和加载状态
  128. 请团队协作完成这个任务,从需求分析到最终实现。"""
  129. # 执行团队协作
  130. print("🚀 启动 AutoGen 软件开发团队协作...")
  131. print("=" * 60)
  132. # 使用 Console 来显示对话过程
  133. result = await Console(team_chat.run_stream(task=task))
  134. print("\n" + "=" * 60)
  135. print("✅ 团队协作完成!")
  136. return result
  137. # 主程序入口
  138. if __name__ == "__main__":
  139. try:
  140. # 运行异步协作流程
  141. result = asyncio.run(run_software_development_team())
  142. print(f"\n📋 协作结果摘要:")
  143. print(f"- 参与智能体数量:4个")
  144. print(f"- 任务完成状态:{'成功' if result else '需要进一步处理'}")
  145. except ValueError as e:
  146. print(f"❌ 配置错误:{e}")
  147. print("请检查 .env 文件中的配置是否正确")
  148. except Exception as e:
  149. print(f"❌ 运行错误:{e}")
  150. import traceback
  151. traceback.print_exc()