ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 30514|回复: 23

[分享] 从字母数字字符串中提取数字

[复制链接]

TA的精华主题

TA的得分主题

发表于 2008-11-19 17:15 | 显示全部楼层 |阅读模式
问题
  如何提取字母数字字符串的数字部分。
  例如:如果单元格A1包含的是字符串“abc123”,则将值123返回单元格 B1 中。
解决方案
  此解决方案的基本原理是搜索并返回字母数字字符串中的第一个数字,然后只返回其后的数字。
算法
  此解决方案包括创建公式以完成下列任务:
1.将字母数字字符串分解为单独的字符。
2.确定分解后的字符串中是否有数字。
3.确定数字在字母数字字符串中的位置。
4.计算字母数字字符串中数字的数量。
  我们将分别考虑这些任务,然后将各公式整合在一起以得到最终结果。
  将字母数字字符串分解为单独的字符
  请在此使用 MID 函数。MID 可以根据所指定的字符的数量,从所指定的位置开始,从文本字符串中返回特定数量的字符。
  此函数的语法是:
  MID(text,start_num,num_chars)
   Text  文本字符串包含的是要提取的字符。
  Start_num  要从文本中提取的第一个字符串的位置。文本中第一个字符占据 start_num 1,以此类推。
  Num_chars  指定要 MID 从文本中返回的字符数量。
  对于我们的示例,公式为:=MID(A1,ROW($1:$9),1) 此公式可以分解字母数字字符串,并且实际上会将字符置于工作表的不同行内。例如,对于字母数字字符串 abc123,其所有 6 个字符都将被分开。
注释
  可将数值 9 适当增大为任何更大的数值,以适应更长的字符串。在此示例中,最大字符串长度为 9。 值得一提的是,字符串分解之后,“1”、“2”和“3”将被看作文本而不是数字。要将存储为文本的数字转换成数字,请用 1 乘以此公式,例如:=1*MID(A1,ROW($1:$9),1) 确定分解后的字符串中是否有数字 在此我们将使用 ISNUMBER 函数,此函数可以确定字母数字字符串中是否有数字。公式现在变成了: =ISNUMBER(1*MID(A1,ROW($1:$9),1))
  如果字符串中有数字,则结果将为 TRUE,否则结果将为 FALSE。
  确定数字在字母数字字符串中的位置。
  现在我们将通过在上一段中提到的分解后的字符串的结果中查找 TRUE 值来确定数字的位置。
  在此我们将使用 MATCH 函数。经过修改的公式现在变为:=MATCH(TRUE,ISNUMBER(1*MID(A1,ROW($1:$9),1)),0)  
要点  
  必须通过按 Ctrl+Shift+Enter 将此公式作为数组进行输入。
  如果字符串是 abc123,则此公式产生的结果将是 4,这就是字母数字字符串中第一个数字字符的位置。
  计算字母数字字符串中数字的数量
  现在的任务是计算字符串中数字的数量,以确定返回字母数字字符串中第一个数字之后要返回的字符。
  如上所述,可通过用 1 与其相乘,将字母数字字符串中存储为文本的数字转换成数字。例如, =1*MID(A1,ROW($1:$9),1)
  将存储为文本的数字转换成数字之后,可以通过使用 COUNT 函数对其进行计数。可通过输入以下公式计算数字的数量:=COUNT(1*MID(A1,ROW($1:$9),1))
整合各公式
  现在我们将使用 MID 函数把此公式的各部分整合在一起,如以下示例所示。 =MID(A1,MATCH(TRUE,ISNUMBER(1*MID(A1,ROW($1:$9),1)),0),COUNT(1*MID(A1,ROW($1:$9),1)))
  从本质上说,此问题可陈述为:确定第一个数字在字母数字字符串(在单元格 A1 中)中的位置。返回此数字及其后的数字。
  要将得到的字符转换成数字,请用 1 乘此公式。虽然对此并不严格要求,但如果要对结果执行数学运算,则应该如此操作。
  下面是要输入单元格 B1 中的最终公式: =1*MID(A1,MATCH(TRUE,ISNUMBER(1*MID(A1,ROW($1:$9),1)),0),COUNT(1*MID(A1,ROW($1:$9),1)))  
要点
  必须通过按 Ctrl+Shift+Enter 将这些公式作为数组进行输入。
  在此值得一提的是,如果字符串是 yur09875reew,而且您使用的是已乘 1 的公式,则列 B 中的结果将是 9875 而不是 09875。因为 0*1=0,所以 0 被忽略了,返回的结果是 9875。如果想得到结果 09875,则不要用 1 乘以整个公式。

评分

3

查看全部评分

TA的精华主题

TA的得分主题

发表于 2008-11-19 17:23 | 显示全部楼层
怎么写论文了呀???这么长的文字叙述!,头晕

TA的精华主题

TA的得分主题

 楼主| 发表于 2008-11-19 17:24 | 显示全部楼层
这篇稿子是在看了yigepure战友的帖子http://club.excelhome.net/viewthread.php?tid=99706
后找到的以函数解决问题的方案,应该更加方便有效。

TA的精华主题

TA的得分主题

 楼主| 发表于 2008-11-19 17:27 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本文的作者是 Ashish Mathur,是一位 Microsoft MVP(最有价值专家)。有关详细信息,请访问 Microsoft MVP 网站(英文)。

TA的精华主题

TA的得分主题

 楼主| 发表于 2008-11-20 12:01 | 显示全部楼层
1*MID(A1,MATCH(TRUE,ISNUMBER(1*MID(A1,ROW($1:$99),1)),0),COUNT(1*MID(A1,ROW($1:$99),1)))
"A2=MID(LEFT(A$1,SMALL(IF(MID(A$1&""*"",ROW($1:$99),1)=""*"",ROW($1:$99),99),ROW(A1))-1),SMALL(IF(MID(""*""&A$1,ROW($1:$99),1)=""*"",ROW($1:$99),99),ROW(A1)),99) "
MID($A$1,ROW(),1)
MID(A1,1,MAX(IF(MID(A1,ROW($1:$99),1)={"0","1","2","3","4","5","6","7","8","9","."},ROW($1:$99))))
MID($A$1,ROW(A1)*2-1,1)

TA的精华主题

TA的得分主题

发表于 2010-11-7 03:47 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2010-11-7 04:31 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2010-11-21 23:33 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2011-1-17 08:23 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
看过,再看。

TA的精华主题

TA的得分主题

发表于 2011-4-19 16:05 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
受教了 我研习了一下午
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-18 08:15 , Processed in 0.033573 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表