乐于分享
好东西不私藏

Excel 中用“-”表示数据区间,如何将区间中的每个数拆分成一行?

Excel 中用“-”表示数据区间,如何将区间中的每个数拆分成一行?

公众号平台最新的推送规则对技术类文章不太友善,如果不想错过干货,请务必“设为星标”哦!!!

点击任意文章上方的“☆星标”即可。

解答网友提问:合并单元格中有独立的数字,也有用连接符号连起来的区间,但是没有规律。如何将合并单元格中包含的每一个数字拆分成一行?

案例:

下图 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. 在弹出的对话框中选择“表”–> 选择“现有工作表”及所需上传至的位置 –> 点击“加载”

这样就得到了一个非常规范的列表。

转发、点赞、在看也是爱!
本站文章均为手工撰写未经允许谢绝转载:夜雨聆风 » Excel 中用“-”表示数据区间,如何将区间中的每个数拆分成一行?

评论 抢沙发

8 + 7 =
  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
×
订阅图标按钮