解答网友提问:合并单元格中有独立的数字,也有用连接符号连起来的区间,但是没有规律。如何将合并单元格中包含的每一个数字拆分成一行?
案例:下图 1 的“地址”列中“-”表示区间,802-804 就是 802 至 804。
根据这个规则,将数据表整理成规范的一维表,地址和物资一一对应。
效果如下图 2 所示。
解决方案:1. 选中数据表的任意单元格 --> 选择工具栏的“数据”-->“从表格”
2. 在弹出的对话框中保留默认设置 --> 点击“确定”
表格已经上传至 Power Query。
3. 选中“地址”列 --> 选择工具栏的“转换”-->“提取”-->“分隔符之前的文本”
4. 在弹出的对话框中输入“室”--> 点击“确定”
5. 选择工具栏的“添加列”-->“自定义列”
6. 在弹出的对话框中将列名设置为“门牌号”--> 输入以下公式 --> 点击“确定”:
Expression.Evaluate("{"&Text.Replace([地址],"-","..")&"}")
公式释义:
Text.Replace([地址],"-",".."):将“地址”列中的“-”替换为“..”;
Expression.Evaluate("{"&...&"}"):
Expression.Evaluate 的作用是将文本表达式或者 M 公式进行求值,返回一个结果;
此处的公式作用是将大括号与“..”连接起来,变成 {地址1..地址2},成为一个数值区间表达式
7. 点开“门牌号”旁边的扩展钮 --> 选择“扩展到新行”
8. 删除“地址”列,将“门牌号”列拖动到最前面。
9. 选择工具栏的“主页”-->“关闭并上载”-->“关闭并上载至”
10. 在弹出的对话框中选择“表”--> 选择“现有工作表”及所需上传至的位置 --> 点击“加载”
这样就得到了一个非常规范的列表。