Power Query中批量处理操作(2)

List.TransformMany(list as list, collectionTransform as function, resultTransfrom as function)as list

第1参数是列表格式;第2参数是对列表需要处理的函数;第3参数是对处理后的列表和原先列表再进行处理的函数,这第3参数的基本固定写法就是(x,y)=>运算公式,x代表原列表(同时需参考第2参数列表的项目数量),y代表通过第2函数参数运算后的列表;返回的也是列表格式。此函数是List.Transform的升级处理,具有2个函数参数。请注意第所有参数最终返回格式也需要是列表格式。

例:

List.TransformMany({1,2,3},each {_+1},(x,y)=>x+y)

={1 +(1+1),2+(2+1),3+(3+1)}

={3,5,7}

解释:第3参数里面的x和y分别代表之前的2个列表。x代表未处理的原始列表,y代表已经通过函数处理过的列表。这两个参数可以用其他变量名替代,但是顺序需要注意。


List.TransformMany({1,2,3}, each{_+1},(x,y)=>x)

={1,2,3}

List.TransformMany({1,2,3},(a)=> {a+1},(x,y)=>y)

=List.Transform({1,2,3},(a)=>a+1)

={2,3,4}

解释:通过以上2个公式,我们基本可以了解到此函数的关键意义。


List.TransformMany({1,2,3},(a)=>{a+1,a+2}),(x,y)=>y

={1+1,1+2,2+1,2+2,3+1,3+2}

={2,3,3,4,4,5}

=List.Combine(List.Transform({1,2,3},(a)=>{a+1,a+2}))

解释:此时的y结果可以理解为一个数组的运算,是原始列表分别通过第2参数进行计算,生成的是一个6个项目的列表。


List.TransformMany({1,2,3},(a)=>{a+1,a+2},(x,y)=>x)

={1,1,2,2,3,3}

解释:虽然x代表的是原始列表,但是如果y列表中是多项处理,则会自动生成重复项,根据第2参数列表项目的数量,重复生成。我们可以根据实际情况来进行选择,如果我们需要的结果和List.Transform一样,那直接到时候引用y就可以了。


List.TransformMany({{1..3},{2..4}},(a)=>{List.Sum},(x,y)=>y(x))

={List.Sum({1..3}),List.Sum({2..4})}

={6,9}

解释:第2参数列表里面直接是一个单函数,所以y(x)代表把x作为参数代入到y函数中,x代表原始列表数据,y代表第2参数的函数列表。


List.TransformMany({1..9},(a)=>{1..9},(x,y)=>Text.From(x)&"*"&Text.From(y))

={"1*1","1*2"…"9*9"}

解释:我们想要生成九九乘法表,这个就是基础。


List.TransformMany({{1..9}},(a)=> List.Select(a, each _>5),(x,y)=>y)

={6,7,8,9}

List.TransformMany({{1..9}}, (a)=>List.Select(a, each _>5),(x,y)=>x)

={{1..9},{1..9},{1..9},{1..9}}

List.TransformMany({{1..9}}, (a)=>List.Select(a, each _>5),(x,y)=>y+List.Sum(x))

={6+45,7+45,8+45,9+45}

={51,52,53,54}


解释:首先第2参数List.Select是针对列表操作,所以在第一参数列表外面再加一层{}。


List.TransformMany({"a","ab","abc"},(a)=>Text.ToList(a),(x,y)=>y)

={"a","a","b","a","b","c"}

List.TransformMany({"a","ab","abc"},(a)=>Text.ToList(a),(x,y)=>x)

={"a","ab","ab","abc","abc","abc"}

解释:根据已知列表内容的字符数来重复值。我们知道x最终返回的结果是要根据y列表的项目数,y列表的项目数是6个,所以最终返回的是6个项目,其重复的项目也是根据y项目来得出的。

如果有用,动动你的小手进行转发。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容