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

基于Dify实现对Excel的数据分析

       在dify部署完成后,大家就可以基于此进行各种应用场景建设,目前dify支持聊天助手(包括对话工作流)、工作流、agent等模式的场景建设,我们在日常工作中经常会遇到各种各样的数据清洗、格式转换处理、数据统计成图等数据分析工作,本次主要基于对话工作流模式对Excel文件、csv文件进行解析处理,并进行成图等数据分析工作。主要用到的插件有LLM节点,文档提取器、参数提取器、自定义代码节点、echart插件等。实现解析Excel数据,经过上述不同节点的处理分析流程,最终实现数据统计图展示。具体如下,供大家参考学习。

一、数据准备

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

二、工作流程设计

总体工作流程图如下。

1.文档提取器
输入变量就是开始节点的文件。
2.LLM节点,提示词设计见下图。

3.参数提取器
输入变量为LLM节点的输出变量text。提取参数和任务指令见下图。

4.自定义代码(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# 创建完整的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": [# 第一个网格中的柱状图系列,注意要根据数据进行删减{"type": "bar", "seriesLayoutBy": "row"},{"type": "bar", "seriesLayoutBy": "row"},{"type": "bar", "seriesLayoutBy": "row"},{"type": "bar", "seriesLayoutBy": "row"},{"type": "bar", "seriesLayoutBy": "row"},{"type": "bar", "seriesLayoutBy": "row"},# 第二个网格中的折线图系列,注意要根据数据进行删减{"type": "line", "xAxisIndex": 1, "yAxisIndex": 1},{"type": "line", "xAxisIndex": 1, "yAxisIndex": 1},{"type": "line", "xAxisIndex": 1, "yAxisIndex": 1},{"type": "line", "xAxisIndex": 1, "yAxisIndex": 1},{"type": "line", "xAxisIndex": 1, "yAxisIndex": 1}]}# 生成输出文件,这里是echart要求的格式输出output = "```echarts\n" + json.dumps(echarts_config, indent=2, ensure_ascii=False) + "\n```"return {"output": output}

5.结束节点,设置回复内容为Exl2Echart节点的输出变量。

三、应用效果演示

运行工作流选择文件后启动对话,在对话框中输入“请分析Excel数据”,即可实现如下效果。编写完成的应用可以嵌入到任意一个应用系统的任何位置,实现对Excel数据的分析工作流。具体效果见下图。

相关文章:

  • 容器技术 20 年:颠覆、重构与重塑软件世界的力量
  • 每日一题洛谷P8615 [蓝桥杯 2014 国 C] 拼接平方数c++
  • jna总结1
  • CSS 盒子模型与元素定位
  • Docker、ECS 与 K8s 网段冲突:解决跨服务通信中的路由问题
  • armv7 backtrace
  • Qt开发经验 --- 避坑指南(14)
  • 数据库与SQL核心技术解析:从基础到JDBC编程实战
  • 软件体系结构(Software Architecture)
  • 【漫话机器学习系列】252.零损失(0-1 Loss)
  • 大数据时代的安全挑战——数据泄露如何悄然发生?
  • 基于PySyft与TensorFlow的医疗数据协同分析系统实现教程
  • 力扣刷题Day 46:搜索二维矩阵 II(240)
  • 【系统架构师】2025论文《系统可靠性设计》【含记忆口诀】
  • 用ffmpeg压缩视频参数建议
  • path环境变量满了如何处理,分割 PATH 到 Path1 和 Path2
  • 安装typescript时,npm install -g typescript报错
  • 编程技能:字符串函数02,strcpy
  • 系统思考:个人与团队成长
  • Pandas学习笔记(四)
  • 在笔墨金石间,看胡问遂与梅舒适的艺术对话
  • Manus向全球用户开放注册
  • 27岁杨阳拟任苏木镇党委副职,系2020年内蒙古自治区选调生
  • 超新星|罚丢点球的那道坎,刘诚宇靠自己迈了过去
  • 库尔德工人党决定自行解散
  • 女高音吴睿睿“古词新唱”,穿着汉服唱唐诗宋词