从事采购及生产运营管理的同学对物料表应该都不陌生。物料表英文为Bill Of Material, 简称BOM。简单说,物料表就是产品原材料清单。这个清单可以是单层的或多层的,因为每个“原”材料也会有它相应的下级物料,以及下下级物料…直到最终分解到最基本的元素,如阳光,空气,铁矿石等等……
实际应用中,我们会根据需要从系统中下载适当层级数的物料表。而物料表的多层结构通常不是很“规范”,如下表1所示,如果我们想快速查询某三级料号对应的上级料号(可能有很多个,如不同大小颜色的铁桶都要使用同种规格的铁板为原材料),这时表1显然无法一次查出完整结果 。
表1 原始物料表
我们希望的物料表结构如表2所示。那要如何从表一转换到表2呢?
?表2 理想物料表结构
这里分享一个用Power Query来解决的思路--选则使用Power Query主要是因为在实际工作中,我们要处理的物料清单会有成百上千,每个都是一个独立从系统下载的文件,而且每个清单里的数据量可能都很大,但基本格式相同。使用Power Query,一切就变得很容易了。
首先将表一读入Power Query。如果是很多张表,可以用文件夹方式读取并合并,用筛选去除不需要的行。
然后把料号与数量合并为一列“料号,数量”,以逗号隔开?。
加入条件列“0级”,具体条件为如果层级为0,则获取相应的“料号,数量”,否则为null。
用类似的方法,加入条件列“1级”,“2级”,“3级”。
选中“0级-2级?”3个新建的条件列,右键菜单选择填充,向下填充。(注意:这里没有选到3级列是因为3级是最后一级,如果选中它再向下填充会误填了上一级的数)
把“0-3级”四个条件列都选中,删除其他列,以保持页面整洁。
选中“3级”列,筛选出非空(null)的行。
最后,利用分列功能将数据还原到我们期望的格式。
最最后,更改一下列名,完成~~
本文所有步骤均为Power Query基本菜单操作,虽然步骤显得有些多,但思路清晰易于理解,而且即使数据量很大时运行速度也非??欤庖彩蔷荼收呔槭褂貌说ゲ僮飨喽杂行└丛幼远ㄒ搴淖畲笥诺?。如果你有不同看法或者有更好的解决思路,欢迎在讨论区分享。