docs/data_analysis_planning_agent.md
基于react_agent.py开发的具有自主规划能力的数据分析智能体,能够理解数据分析需求、制定分析计划并系统性地执行。
DataAnalysisPlanningAgent
├── 继承自 ConversableAgent
├── 扩展 ReActAgent 的规划能力
└── 集成数据分析专用工具
class DataAnalysisPlanningAgent(ConversableAgent):
analysis_plan: Optional[List[Dict[str, Any]]] # 分析计划
current_step: int = Field(default=0) # 当前步骤
planning_complete: bool = Field(default=False) # 规划完成状态
create_analysis_plan: 创建分析计划examine_data_sources: 检查数据源load_data: 加载数据explore_data: 探索性分析statistical_analysis: 统计分析create_visualization: 创建可视化generate_insights: 生成洞察_DATA_AGENT_SYSTEM_TEMPLATE = """
You are an expert data analyst with strong planning and execution capabilities.
1. Planning Phase: 理解目标、识别数据、创建计划
2. Execution Phase: 加载数据、执行分析、生成结果
3. Communication Phase: 展示发现、提供洞察、建议后续
"""
from dbgpt.agent.expand.data_agent import DataAnalysisPlanningAgent
from dbgpt.agent.resource import ToolPack, ResourcePack
# 1. 创建工具
tools = [DataSourceTool(), LoadDataTool(), ExploreDataTool()]
tool_pack = ToolPack(tools=tools)
# 2. 创建资源包
resource_pack = ResourcePack()
resource_pack._resources["tools"] = tool_pack
# 3. 创建Agent
agent = DataAnalysisPlanningAgent(resource=resource_pack)
# 4. 发送分析请求
message = AgentMessage(content="分析销售数据趋势,提供业务洞察")
response = await agent.act(message, sender=None)
# 自定义规划参数
agent = DataAnalysisPlanningAgent(
max_retry_count=25, # 增加重试次数
resource=resource_pack,
llm_client=your_llm_client
)
# 设置分析目标
agent.profile.goal = "专注于电商数据分析,提供精准的业务洞察"
用户输入 → 理解业务问题 → 识别分析目标 → 确定数据需求
数据需求 → 检查数据源 → 制定分析计划 → 估算时间和资源
执行计划 → 数据加载 → 探索分析 → 深度分析 → 结果验证
分析结果 → 生成洞察 → 创建可视化 → 提供建议 → 完成任务
question = "分析我们的销售数据,识别趋势并提供业务规划洞察"
# Agent会自动执行:
# 1. 创建销售趋势分析计划
# 2. 检查可用的销售数据源
# 3. 加载销售数据
# 4. 进行趋势分析
# 5. 生成可视化图表
# 6. 提供业务洞察和建议
question = "进行客户细分分析,识别不同客户群体特征"
# Agent会自动执行:
# 1. 制定客户细分分析计划
# 2. 检查客户数据
# 3. 执行细分算法
# 4. 分析各群体特征
# 5. 提供营销建议
class CustomAnalysisTool(BaseTool):
@property
def name(self) -> str:
return "custom_analysis"
@property
def description(self) -> str:
return "执行自定义分析逻辑"
async def async_execute(self, **kwargs):
# 实现自定义分析逻辑
return {"result": "自定义分析结果"}
# 添加到Agent
agent.resource._resources["custom_analysis"] = CustomAnalysisTool()
class CustomDataAnalysisAgent(DataAnalysisPlanningAgent):
async def create_custom_plan(self, objective: str):
# 实现自定义规划逻辑
custom_plan = [
{"step": 1, "action": "custom_preprocessing"},
{"step": 2, "action": "custom_analysis"},
]
self.analysis_plan = custom_plan
return custom_plan
问题: Agent无法创建有效的分析计划
解决: 检查数据源可用性,明确分析目标
问题: 数据分析工具执行失败
解决: 检查工具参数,验证数据格式
问题: 分析结果不够深入或准确
解决: 提供更多背景信息,调整分析策略
# 启用详细日志
import logging
logging.basicConfig(level=logging.DEBUG)
# 检查Agent状态
print(f"Planning complete: {agent.planning_complete}")
print(f"Current step: {agent.current_step}")
print(f"Analysis plan: {agent.analysis_plan}")
欢迎提交Issue和Pull Request来改进这个项目!
# 安装依赖
pip install -r requirements.txt
# 运行测试
pytest tests/
# 代码格式化
black src/
MIT License - 详见LICENSE文件