Table.Group函数使用自定义函数进行汇总。

今天用一个例子讲解一下在Power Query中,Table.Group()函数如何使用自定义函数进行汇总。

该函数的基本语法和使用示例参考:

Table.Group函数使用自定义函数进行汇总。_第1张图片

我们看上图示例可以明白,这个函数是以第二参数作为分组字段(或者字段列表),第三参数就是一个列表。示例中“total”就是汇总后结果的字段名称。那么是对哪个字段分组列表进行什么样的汇总方式呢?我们看到List.Sum([price]),就可以明白是对表中的price字段进行分组加和的汇总。如果我们使用自定义函数fx我们就要知道我们传递的参数是什么。从list.sum求的是根据分组后的每个子表进行price的求和。那么我们就知道我们传递给函数的是分组的列表。

那么如何使用自定义函数呢?我们来看一下如下图所示的例子。我们要求的是按照字母统计数字的个数以及数字组合列表。

Table.Group函数使用自定义函数进行汇总。_第2张图片

 求次数比较简单,对分组的字段使用List.Count()函数就能搞定。那么如何进行合并呢。我们有Text.Combine()函数可以合并列表中的成员。这里因为是数字,我们不能直接合并,需要将成员转化为text类型再进行合并。因为上面已经说明汇总是对分组后的字段列表的某种形式的聚合。我们需要传递的参数应该是一个list的类型。看下面的定义方式:

fx=(x as list)=>Text.Combine(List.Transform(x,each Text.From(_)),",")

这个自定义函数很好理解.就是将list里面的每个成员转化为text类型,然后以逗号进行连接起来。

最后整个汇总的M代码如下:

let
    源 = Excel.CurrentWorkbook(){[Name="表1"]}[Content],
    fx=(x as list)=>Text.Combine(List.Transform(x,each Text.From(_)),","),
    data=Table.Group(源,"字母",{{"次数",each List.Count([数字])},{"数字合并",each fx([数字])}})
in
    data

结果如图所示,符合预期:

Table.Group函数使用自定义函数进行汇总。_第3张图片

你可能感兴趣的:(Power,Query)