Table.TranformColumnNames()主要用于批量修改表格字段名称,该函数可抽象为function( table as table, nameGenerator as function, Optional options as nullable record) as table。第一个参数是只能是表格类型的变量,第二个参数可以理解为以字段名称为自变量的某函数结果。第三个参数不一定要填,如有需要只能以记录形式进行填写,主要用来控制字段最大字符数以及比较规则。
data:image/s3,"s3://crabby-images/4202e/4202e5c037ab227a0b192fc76653ec6d1cebe118" alt=""
情景一:以上为表格Employee,字段名称以表格名称开头紧跟着带中括号的字段描述,现在需要把字段名称中的表格名称以及中括号去掉,达到这个效果的M语言代码为:
= Table.TransformColumnNames( Empolyee, each Text.BetweenDelimiters( _, "[", "]" ) )
data:image/s3,"s3://crabby-images/40b80/40b8089b178a1b9c9aa807beacfd2694085cff20" alt=""
情景二:把表格Employee的所有字段的小写字母改为大写字母,以下为现实这个目的的M语言代码:
= Table.TransformColumnNames( Empolyee, each Text.Upper( _ ) )
data:image/s3,"s3://crabby-images/45df1/45df155e5902ddcbd58d35226d5c1051cba3d515" alt=""
情景三:如果仅需要保留中括号以及其中的内容,可以使用以下M语言代码:
= Table.TransformColumnNames( Empolyee, each Replacer.ReplaceText( _, "Employee", "" ) )
data:image/s3,"s3://crabby-images/0d9c8/0d9c8164d096dc4419582b59e9b14357e1c70215" alt=""