目前,我在 Excel 中有一个大表,我想将其与动态下拉列表(级联选项)一起使用。根据您在第一个下拉菜单中所做的选择,然后在下一个单元格中,您应该有一个经过筛选的下拉菜单。此外,任何选项对于所选的主类别都是唯一的。
我做的第一件事是获取我需要的列并对它们进行透视,使其看起来与此类似(C 是列名称,V 是值。由于任何选项对于任何类别都是唯一的,因此我遇到了空值问题,因为它是大量的行):
C1 | C2 | C3
V1 | null | null
V2 | null | null
null | V3 | null
null | null | V4
null | null | V5
此格式对于动态下拉列表无法正常工作,因为它首先显示所有空字段。
我的问题是是否有任何方法可以使用 power query 删除空值,以便我可以在第一行中请求所有值,例如:
C1 | C2 | C3
V1 | V3 | V4
V2 | null | V5
null | null | null
null | null | null
null | null | null
我尝试过使用“填充”或“填充”选项,然后删除重复项,但不起作用,因为它多次重复相同的元素,这对于最终的下拉菜单没有用处。
不确定是否有办法实现它,因此非常感谢任何帮助或建议。
提前致谢!
由于列是独立的,因此您可以将每一列转换为一个列表,删除空值,然后将它们组合回一个表中。
Table.FromColumns(
{
List.RemoveNulls(Pivot[C1]),
List.RemoveNulls(Pivot[C2]),
List.RemoveNulls(Pivot[C3])
},
{"C1","C2","C3"}
)
Result:
如果列数不总是三,那么这可以变得更加动态,但应该应用相同的想法。
Edit:
实际上,它比我最初预期的更简单,使其动态化,与列数及其名称无关:
Table.FromColumns(
List.Transform(Table.ToColumns(Pivot), List.RemoveNulls),
Table.ColumnNames(Pivot)
)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)