我在Excel中有以下PowerQuery
let
Source = Excel.CurrentWorkbook(){[Name="Query1"]}[Content],
#"Changed Type" = Table.TransformColumnTypes(Source,{{"Month Year", type date}}),
#"Custom Step" = Table.SelectRows(#"Changed Type", each [Month Year] = #date(2017, 12, 1))
in
#"Custom Step"我想把它设置为#date(2017,12,1)是一个参数。换句话说,我希望在工作表上有一个过滤器/下拉列表,以及用户选择的任何内容(2017年12月、2016年11月等)。我想要“自定义步骤”来过滤基于选择的表格。
是否有某种语法允许我使用参数?(有点像SQL中的@变量)
发布于 2018-03-26 20:36:02
获取查询参数的方法有很多种。您可以使用一个命名的范围并直接访问它,或者使用一个函数访问它,或者您甚至可以构建一个包含多个参数的表,并使用一个函数访问它们。Ken为参数表这里提供了一个很好的起点
只要使用一个参数,您就可以简单地使用一个命名范围。在下面的屏幕截图中,单元格F4的范围名为SelectedDate。使用行很容易获得此参数。
myDate = Excel.CurrentWorkbook(){[Name="SelectedDate"]}[Content]{0}[Column1]但是结果将是文本,不能正确地过滤表。您需要将其转换为日期,例如将其包装为Date.From函数。
myDate = Date.From(Excel.CurrentWorkbook(){[Name="SelectedDate"]}[Content]{0}[Column1]),现在可以使用变量myDate来筛选表。以下是完整的M代码:
let
myDate = Date.From(Excel.CurrentWorkbook(){[Name="SelectedDate"]}[Content]{0}[Column1]),
Source = Excel.CurrentWorkbook(){[Name="Query1"]}[Content],
ChangedType = Table.TransformColumnTypes(Source,{{"Month Year", type date}}),
Filtered = Table.SelectRows(ChangedType, each [Month Year] = myDate )
in
Filtered

https://stackoverflow.com/questions/49498840
复制相似问题