【Power Query】M函数-List.Sum

M函数-List

    • 列表求和 (List.Sum):
      • 1)横向求和
      • 2)列求和
        • ★思路★</font>
        • ★实操★</font>
      • 3)求总和
      • 4)求部分占总体的比重
        • ★横向★</font>
        • ★竖向★</font>

列表求和 (List.Sum):

|------------------------------|
| List.Sum({里面必须是一整个列表,不是零碎的}) |

返回列表中非空的所有值的总和
例如:List.Sum({1,2,3}) 表示求{1,2,3}这样一个列表的和,也就是6
通常嵌套使用

1)横向求和

这是直接选项卡添加自定义列来求和的写法:
直接语数英相加

用M函数的话:
= Table.AddColumn(提升的标题, "总分", each List.Sum({Chinese,Math,English}))
同样的字段,但是要多加两层括号

2)列求和

★思路★

|-------------------------------------------------------------------------|
| 1. 首先对列求和要提取出这一列:表字段,再用 List.Sum(表字段) 对列求和。★本身已经是列表了,不需要再加{}大括号 |

|------------------------------------------------------------------------------------------------------|
| 2. 再用 键值对 的形式写出 记录。字段1=List.Sum(表\[字段1),字段2=List.Sum(表\[字段2)]。★不需要求和的记录直接赋值:例,姓名="各科总分" |

|--------------------------------------------------------------------|
| 3. 接着是将记录转成表。用 Table.FromRecords({记录})。★记录要先转 列表 ,再转表,所以外面要先加{}大括号 |

|------------------------------------------|
| 4. 最后将现今的表 和 转成的表 合并。用 & 连接就可以了。★注意先后顺序 |

★实操★

假设我要 求 语数英 各科目的总分

利用高级编译器来写,位置如下:

在结束之前,每一步后面都跟上一个逗号,输出结果写在in后面


  • 源= Excel.CurrentWorkbook(){Name="表10"}Content,

  • 列求和记录 = NAME="各科总分"`,`Chinese=List.Sum(源\[Chinese),Math=List.Sum(源Math),English=List.Sum(源English)],

  • 转表 = Table.FromRecords({列求和记录}),

  • 合并表 = 源 & 转表


相当于是把每一步拆开,逻辑更加清晰,结果如下:

3)求总和

其实也就是同时求多列的和, 因为 List.Sum 里只包含一个列表, 所以要把它们整合成一个列表 可以用&来连接 ,例如:

=List.Sum(更改的类型[北京] & 更改的类型[上海] & 更改的类型[深圳])

4)求部分占总体的比重

★横向★

也就是用横向求和 去除以总和 单单这么做只会得出一个数字,要每一列都用上的话,那就需要【添加列】AddColumn

|------------------------------------|
| 横向的和:List.Sum({A,B,C}) |

|-----------------------------------------------------|
| 总和:List.Sum(更改的类型A & 更改的类型B & 更改的类型C) |

|-----------------------------------------------------------------------------------------------------------------------------------|
| = Table.AddColumn(更改的类型,"占比",each List.Sum({A,B,C})/List.Sum(更改的类型A & 更改的类型B & 更改的类型C),Percentage.Type) |


Percentage.Type 是用来更改新增这列的类型为【百分比】的,不加它,就默认是小数喽~


★竖向★


步骤如下:缺点是占比不是百分比的形式

|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 生成新记录 = Month="占比",A=List.Sum(更改的类型\[A)/List.Sum(更改的类型A & 更改的类型B & 更改的类型C),B=List.Sum(更改的类型B)/List.Sum(更改的类型A & 更改的类型B & 更改的类型C),C=List.Sum(更改的类型C)/List.Sum(更改的类型A & 更改的类型B & 更改的类型C)], |

|----------------------------------|
| 转表 = Table.FromRecords({生成新记录}), |

|-------------------|
| 合并表 = 更改的类型 & 转表 |

∗ ∗ t h a n k s ∗ ∗ **thanks** ∗∗thanks∗∗

相关推荐
chushiyunen1 小时前
langchain4j笔记、tools
笔记·python·flask
影视飓风TIM3 小时前
数据结构 | 链表超全笔记(单链表+双链表+高频算法题)
数据结构·笔记·链表
二哈赛车手3 小时前
新人笔记---最终版智能体图片分析完整方案,包括一些总结于经验,以及各种优化点讲解
java·笔记·spring·ai·springboot
_李小白3 小时前
【智能驾驶:视觉感知后处理 阅读笔记】Day4: 相机成像模型与畸变
笔记·数码相机
十月的皮皮4 小时前
C语言学习笔记20260615-有序升序序列合并
c语言·笔记·学习
辣香牛肉面6 小时前
CintaNotes个人笔记管理软件v3.14(v3.13.0 绿色汉化版)
笔记
数据库小学妹7 小时前
SQL Server数据库同步工具怎么选?6款方案对比+信创迁移避坑清单
数据库·经验分享·sqlserver·dba
星越华夏8 小时前
软考程序员备考资料
经验分享
yoothey9 小时前
异常学习笔记:为什么自定义异常后还要 throw?
笔记·学习
sulikey9 小时前
数据库系统概论4 - 更新与视图 期末速成课笔记
数据库·笔记·考试·期末速成·数据库系统概论