为空 Power Query 时上移值

Posted

技术标签:

【中文标题】为空 Power Query 时上移值【英文标题】:Move up values when null Power Query 【发布时间】:2020-11-12 10:53:50 【问题描述】:

此时我在 Excel 中有一个大表,我想将其与动态下拉列表(级联选项)一起使用。根据您在第一个下拉菜单中所做的选择,然后在下一个单元格中,您应该有一个过滤的下拉菜单。此外,任何选项对于所选的主要类别都是唯一的。

我做的第一件事是获取我需要的列并将它们旋转,使其看起来与此类似(C 是列名,V 是值。由于任何选项对于任何类别都是唯一的,因此我遇到了问题null 值,因为它是大量行):

C1   | C2   | C3
V1   | null | null
V2   | null | null
null | V3   | null
null | null | V4
null | null | V5

此格式不适用于动态下拉菜单,因为它首先显示所有空字段。 我的问题是是否有任何方法可以使用 power 查询删除空值,以便我可以在第一行中请求所有值,例如:

C1   | C2   | C3
V1   | V3   | V4
V2   | null | V5
null | null | null
null | null | null
null | null | null

我已尝试使用“填充”或“填充”选项,然后删除重复项,但无法正常工作,因为它多次重复相同的元素,这对最终的下拉菜单没有用处。

不确定是否有办法实现它,因此非常感谢任何帮助或建议。

提前致谢!

【问题讨论】:

【参考方案1】:

由于列是独立的,您可以将每一列变成一个列表,删除空值,然后将它们组合回一个表中。

Table.FromColumns(
    
        List.RemoveNulls(Pivot[C1]),
        List.RemoveNulls(Pivot[C2]),
        List.RemoveNulls(Pivot[C3])
    ,
    "C1","C2","C3"
)

结果:

如果列数不总是三但应该应用相同的想法,这可以变得更加动态。


编辑:

它实际上比我最初预期的要简单,使其动态化,独立于列数及其名称:

Table.FromColumns(
    List.Transform(Table.ToColumns(Pivot), List.RemoveNulls), 
    Table.ColumnNames(Pivot)
)

【讨论】:

感谢您的 cmets!我必须考虑一下,因为它完全有用,但我有 219 列,并且有可能列是可变的。如果您有任何想法,我将不胜感激。再次感谢您! 我可以在新工作表中使用 VBA 完成此操作,只需复制并粘贴电源查询的结果。代码形成每一列并删除空单元格并提升值。谢谢 这太棒了!非常感谢!

以上是关于为空 Power Query 时上移值的主要内容,如果未能解决你的问题,请参考以下文章

Power Query,刷新时保持输出表相同大小

ie 11 cookie 的值为空

为啥字符串值为空?

数据绑定值为空时如何在 DataGridViewComboBoxColumn 中显示文本

强制值为空时无法引发 VALUE_ERROR

如何在Power Query中提取数据——列表篇(1)