当前位置: 首页 > ops >正文

基于Dify实现对Excel的数据分析--动态配置图表

在之前的Excel数据分析文章发出后,网友们都在咨询如何实现根据数据情况动态调整图表输出,其实这个不难,这几天抽空做了一个简单实现。主要原理就是在series模板中做工作,其他内容和之前文章类似,这里就不重复了,主要提供自定义代码完整内容。具体如下,供大家参考学习。

一、数据准备

准备一个Excel文件,内容可以是产品月度销售数据或者油气田月度产量数据等。如下图。

二、工作流程设计之自定义代码

自定义代码(Exl2Echart)代码,代码需要在sandbox容器中执行,目前主要支持python和nodejs代码,记得安装相应的依赖库。本文中的csv和json库都是默认安装的。代码详见下方

import csv
import json
def main(csv_string):# 将CSV字符串分割成行lines = csv_string.strip().split('\n')# 使用csv模块读取数据reader = csv.reader(lines)# 将所有行转换为列表data = [row for row in reader]# 将数字字符串转换为浮点数for row in data[1:]:  # 跳过标题行,即第一行# 将第二列及之后的所有列的数据类型调整为数字类型(这里是float)for i in range(1, len(row)):try:row[i] = float(row[i])except ValueError:pass# 根据数据情况动态增加图表配置。主要是修改series,这个其实与大模型无关。  custom_series=[]  # 1.柱状图:根据data行数增加series列表数据  for row in range(len(data)-1):  # 第一个网格中的柱状图系列,取决于行数。  type_schema={"type": "bar", "seriesLayoutBy": "row"}  custom_series.append(type_schema)  # 2.折线图:根据data列数增加series列表数据  for row in range(len(data[0])-1):  # 第二个网格中的折线图系列,取决于列数  type_schema={"type": "line", "xAxisIndex": 1, "yAxisIndex": 1}  custom_series.append(type_schema)# 创建完整的ECharts配置echarts_config = {"legend": {},"tooltip": {},"dataset": {"source": data},"xAxis": [{"type": "category", "gridIndex": 0},{"type": "category", "gridIndex": 1}],"yAxis": [{"gridIndex": 0},{"gridIndex": 1}],"grid": [{"bottom": "55%"},{"top": "55%"}],"series": custom_series}# 生成输出文件,这里是echart要求的格式输出output = "```echarts\n" + json.dumps(echarts_config, indent=2, ensure_ascii=False) + "\n```"return {"output": output}
三、应用效果演示

运行工作流后,选择文件后启动对话,在对话框中输入“请分析Excel数据”,即可实现如下效果。演示示例是2个油田4个月度数据,如果用户提供了更多的数据,该agent会自动解析数据,形成多列多行的图表数据,实现对Excel数据分析,大家可以试试。

http://www.xdnf.cn/news/17334.html

相关文章:

  • Flutter 视频播放video_player、chewie
  • 欧拉公式的意义
  • 管家婆软件固定资产管理常见问答
  • 自动化一键部署 LNMP 环境
  • 深度学习入门Day8:生成模型革命——从GAN到扩散模型
  • 如何优雅的使用进行参数校验
  • Day02 员工管理,分类管理
  • 202506 电子学会青少年等级考试机器人六级器人理论真题
  • 黑马SpringAI项目-聊天机器人
  • DeepSeek智能考试系统智能体
  • 大语言模型提示工程与应用:ChatGPT提示工程技术指南
  • 华为实验NAT
  • [Oracle] ADD_MONTHS()函数
  • 【Avalonia】无开发者账号使用iOS真机调试跨平台应用
  • 【SpringBoot】SpringWeb的开发
  • Cursor CLI 来了,准备 Build anything
  • ESP32-menuconfig(3) -- Serial flasher config
  • 四、redis入门之集群部署
  • 【LLM开发学习】
  • 应用层自定义协议
  • Redis基础数据类型
  • 广东省省考备考(第七十天8.8)——言语、判断推理(强化训练)
  • 01Vue3
  • [优选算法专题一双指针——三数之和]
  • Python训练营打卡Day26-函数专题2:装饰器
  • 最长回文子串
  • 远期(Forward)交易系统全球金融市场解决方案报告
  • Java 之 设计模式
  • Python名称映射技术:基于序列元素的高级访问模式详解
  • [科普] AI加速器架构全景图:从GPU到光计算的算力革命