n8n第二节 实现小卖部商品财务报表自动化生成

思路与效果

输入小卖部各商品的基础销售信息,通过数据计算、提取、转换等步骤,最终输出包含商品类别、销售额、利润额的结构化报表。整体思路围绕 "数据输入 - 数据处理 - 结果输出" 三大环节展开,具体分为 5 个关键步骤,形成闭环工作流:

  1. 输入销售情况
  2. 统计销售额
  3. 提取商品种类和销售额
  4. 得到各种类商品的利润 根据商品种类区分不同的利润,
  5. 输出各种类商品的利润一览表

实现

代码-销售情况

简易版省了前摇直接输入了,作为参考。

set-销售额

销售额是财务报表的核心指标,其计算逻辑为 "销售数量 × 单价"。

aggregate-提取需要的项

经过销售额计算后,数据仍以分散的字典形式存在,无法直接用于按类别分配不同利润率的运算。因此需要通过 "Aggregate"(聚合)节点对数据进行整合:该节点的核心作用是将分散的文本类型数据合并转为列表形式,具体提取 "product_category"(商品类别)和 "sum"(销售额)两个关键字段,分别生成对应的列表数组。

代码-算利润

利润核算是财务报表的核心环节,不同品类商品的利润率存在天然差异(如文具类商品利润率较低,特色零食类利润率较高),因此需按商品类别区分设置不同利润率。这一步骤通过 "代码" 节点实现,核心依赖 JavaScript 中的map数组方法完成数据遍历与转换。

map 是 **数组的核心遍历转换方法,**逻辑:遍历数组 → 按索引关联其他数据 → 生成新数组。

json.product_category.map(...),可以拆解成 3 个关键步骤:

  1. 遍历源数组json.product_category 是源数组(比如 ["文具类", "图书类", "数码类"]),map 会逐个 "扫过" 这个数组的每一项;
  2. 给每一项做处理
    • 回调函数 (p, s) => {...} 是 "处理规则":
      • p:当前遍历到的数组项(比如第一次取 product_category[0] = "文具类",第二次取product_category[1] = "图书类");
      • s:当前项的索引 (从 0 开始,第一次是 0,第二次是 1,第三次是 2),用来对应 json.sumprofits 数组的同位置数据(比如 json.sum[s] 就是当前分类对应的销售额);
    • 处理结果是一个新对象 { json: { product_category: p, sales_sum: ... } }(即 n8n 要求的格式);
  1. 收集结果返回 :把每一项的处理结果(新对象)汇总起来,形成一个全新的数组,最后通过 return 输出。

一句话总结工作流代码中 map 的作用:

json.product_category 数组的每一个 "商品类别",和 json.sum 对应的 "销售额"、profits 对应的 "利润率" 绑定,生成一个包含 product_categorysales_sumprofit_sum 的 n8n 标准格式数组。

简化例子来理解map:

比如源数组是 ["A类", "B类", "C类"],用 map 处理:

javascript

运行

复制代码
const arr = ["A类", "B类", "C类"];
const newArr = arr.map((item, index) => {
  return { 类别: item, 索引: index, 计算值: index + 10 };
});
// newArr 最终是:
// [
//   { 类别: "A类", 索引: 0, 计算值: 10 },
//   { 类别: "B类", 索引: 1, 计算值: 11 },
//   { 类别: "C类", 索引: 2, 计算值: 12 }
// ]

set-报表一览

将上个节点输出的3个列表项根据名称顺序拖到输入框里,写上文字说明,会自动分成三条输出。

小记

总的来说,这个工作流就是按"输入数据→算销售额→整合信息→算利润→出报表"的步骤来的,直接让小卖部的简易财务报表自动生成啦。

相关推荐
noBt1 天前
Windows IDEA 卡顿严重
java·ide·intellij-idea
h7ml1 天前
淘宝返利软件的跨端同步架构:Java RESTful API+GraphQL满足Web/APP/小程序的多端数据需求
java·架构·restful
qq_336313931 天前
javaweb-web基础(springboot入门)
java·开发语言·mysql
闻哥1 天前
从测试坏味道到优雅实践:打造高质量单元测试
java·面试·单元测试·log4j·springboot
smileNicky1 天前
统一网关的登录流程总结
java
计算机程序设计小李同学1 天前
基于 Spring Boot + Vue 的龙虾专营店管理系统的设计与实现
java·spring boot·后端·spring·vue
LiZhen7981 天前
SpringBoot 实现动态切换数据源
java·spring boot·mybatis
周航宇JoeZhou1 天前
JB2-7-HTML
java·前端·容器·html·h5·标签·表单
JZC_xiaozhong1 天前
多系统权限标准不统一?企业如何实现跨平台统一权限管控
java·大数据·微服务·数据集成与应用集成·iam系统·权限治理·统一权限管理
爬山算法1 天前
Hibernate(85)如何在持续集成/持续部署(CI/CD)中使用Hibernate?
java·ci/cd·hibernate