excel怎么提取单元格中的数字_excel从混合文本中提取数字的方法

冰火之心
发布: 2025-09-14 08:59:01
原创
1552人浏览过
首先使用公式提取连续数字,再通过FIND与MID组合提取首个数字段,接着用VBA自定义函数遍历字符获取所有数字,最后利用Power Query批量处理数据并提取数字。

excel怎么提取单元格中的数字_excel从混合文本中提取数字的方法

如果您在处理包含文字与数字混合的单元格时,希望仅提取其中的数字部分,可以使用多种方法实现。Excel本身不提供直接提取数字的内置函数,但可以通过公式组合或工具辅助完成。

本文运行环境:Dell XPS 13,Windows 11

一、使用公式提取连续数字

通过嵌套函数组合可以从文本开头或中间提取连续的数字字符。此方法适用于数字位于文本前段且连续的情况。

1、在目标单元格中输入以下数组公式:=TEXTJOIN("",TRUE,IF(ISNUMBER(--MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1)),MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1),""))

2、输入完成后按 Ctrl + Shift + Enter 确认,Excel会自动添加花括号表示数组公式。

3、将公式向下填充以应用到其他行。

二、提取首个连续数字段(适用于含多个数字的文本)

当单元格中包含多个数字片段时,可通过此方法提取第一个出现的数字序列。

1、使用FIND定位第一个数字出现的位置:=MIN(IF(ISNUMBER(--MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1))*1,ROW(INDIRECT("1:"&LEN(A1)))))

2、结合MID函数提取从该位置开始的连续数字:=IFERROR(MID(A1,MATCH(TRUE,ISNUMBER(--MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1)),0),SUMPRODUCT(--ISNUMBER(--MID(MID(A1,MATCH(TRUE,ISNUMBER(--MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1)),0),LEN(A1)),ROW(INDIRECT("1:"&LEN(A1))),1)))),"")

3、同样需以 Ctrl + Shift + Enter 输入数组公式。

三、使用VBA自定义函数提取所有数字

VBA能够遍历每个字符并判断是否为数字,适合复杂场景下的灵活处理。

阿里云-虚拟数字人
阿里云-虚拟数字人

阿里云-虚拟数字人是什么? ...

阿里云-虚拟数字人 2
查看详情 阿里云-虚拟数字人

1、按 Alt + F11 打开VBA编辑器,插入新模块。

2、粘贴以下代码:

Function ExtractNumbers(cellRef As Range) As String
Dim i As Integer
Dim result As String
For i = 1 To Len(cellRef.Value)
If IsNumeric(Mid(cellRef.Value, i, 1)) Then
result = result & Mid(cellRef.Value, i, 1)
End If
Next i
ExtractNumbers = result
End Function

3、关闭编辑器,在工作表中使用函数 =ExtractNumbers(A1) 即可返回所有数字拼接结果。

四、利用Power Query拆分并提取数字

Power Query适合批量处理大量数据,通过字符拆分和筛选实现数字提取。

1、选择数据区域,点击「数据」选项卡中的「从表格/区域」加载至Power Query。

2、在Power Query编辑器中选中目标列,点击「转换」→「格式」→「提取」→「仅数字」。

3、若无此选项,可手动添加自定义列,使用表达式:Text.Select([Column1],{"0".."9"})

4、点击「关闭并上载」,结果将写回Excel工作表。

以上就是excel怎么提取单元格中的数字_excel从混合文本中提取数字的方法的详细内容,更多请关注php中文网其它相关文章!

WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号