Excel Power Query:对列值使用List.MatchAny

时间:2017-08-10 21:33:12

标签: excel list matching powerquery

在Excel Power Query中,我有一个表。 A列有单个数字。我想标记列A值与列表匹配的那些记录。该问题的缩减版本是:

let
    TableA = Table.FromColumns({{1,2,4}}, {"A"}),
    ListB = {4,5,6 },
    DPart = Table.AddColumn(TableA, "IsInB", 
            List.MatchesAny(ListB, each _ = [A]))
in
    DPart

我在DPart行中出现错误

Expression.Error: We cannot apply field access to the type Number.
Details:
  Value=4
  Key=A

显然,代码试图访问列表元素的[A]列,而不是TableA的[A]列。

完成此任务的正确语法是什么?

1 个答案:

答案 0 :(得分:-1)

这有效:

let
    TableA = Table.FromColumns({{1,2,4}}, {"A"}),
    ListB = {4,5,6 },
    DPart = Table.AddColumn(TableA, "IsInB", 
            (x) => List.MatchesAny(ListB, each _ = x[A]))
in
    DPart

但我更愿意:

let
    TableA = Table.FromColumns({{1,2,4}}, {"A"}),
    ListB = {4,5,6 },
    DPart = Table.AddColumn(TableA, "IsInB", 
            each List.Contains(ListB, _[A]))
in
    DPart