强大的查询:将列名作为函数参数

时间:2019-04-25 00:12:00

标签: powerquery

我正在努力将列名传递给幂查询函数-如果我在函数调用内将它们作为[columnname]传递,它将尝试在函数外部实现它们;如果我在函数本身内使用[parameter]传递,它将查找列“ parameter”而不是调用中传递的列名。

在其他地方,StackExchange建议使用Table.Column(table,columnname)解决此问题,但是我一口气获得了整个列,而不是能够比较该列中的相应条目。

有人可以帮忙吗?这是代码

(table,Mt0,Mt1) => let 
    #"Add Yt.1" = Table.AddColumn(table, "placeholder", 
        each if Table.Column(table,Mt0) <= 0 or - Table.Column(table,Mt1) < Table.Column(table,Mt0)
            then Table.FromRecords({[Mt0 = Table.Column(table,Mt0), Mt1 = Table.Column(table,Mt1)]})
        else Table.FromRecords({[Mt0 = 0,Mt1 = Table.Column(table,Mt1) + Table.Column(table,Mt0)]}))/*,
    #"Expand Yt.1" = Table.ExpandTableColumn(Table.RemoveColumns(#"Add Yt.1",{"Mt0", "Mt1"}), "placeholder", {"Mt0","Mt1"})*/
in #"Add Yt.1"

此存储为Query1,我正在使用Query1(tablename,Y1M,Y2M)调用

此版本产生错误:     我们不能将运算符“ <=”应用于类型List和Number (因此,尽管它可能按预期引用了Y1M列,但它会将第一个不等式中的整个列(作为列表)与“ 0”进行比较,而不是一次比较一个条目。

帮助!

2 个答案:

答案 0 :(得分:0)

尝试使用Record.Field(_, Mt0)代替Table.Column

答案 1 :(得分:0)

这非常有帮助。这让我有点发疯。无效的代码,然后无效的代码。

这不起作用

(tablename as table, columnname as text)=>

let
// results in new column with all values null 
Source = tablename,
GetColumn = Table.AddColumn(Source, "Text", each ```Text.Middle(columnname, 32, 7 ) , type text)
in
GetColumn 

使用(Record.Field(_, columnname))确实有效

(tablename as table, columnname as text)=>
let
results in new column with characters properly ```extracted from the column specified with ```columnname when invoking the function
Source = tablename,
GetColumn = Table.AddColumn(Source, "Text", 
each Text.Middle(Record.Field(_, columnname), 32, 7), type text)
in
GetColumn

谢谢!