excelperfect

上篇文章讲解了提取位于字符串开头的数字的公式技术,本文研究从字符串开头提取数字的技术:

1. 这些数字是连续的

2. 这些连续的数字位于字符串的末尾

3. 想要的结果是将这些连续的数字返回到单个单元格

与上篇文章一样,对于下面研究的每种解决方案,我们需要在两种不同的情况下测试其健全性:

1. 字符串中除末尾外其他地方没有数字的情况,例如ABC456。

2. 字符串中除末尾外其他地方也有数字,要么在开头,要么在中间,例如123ABC456或ABC123DEF456。

MIN与FIND

公式1:

=0+MID(A1,MIN(FIND({0,1,2,3,4,5,6,7,8,9},A1& 1/17)),LEN(A1))

如果单元格A1中的内容为“ABC456”,那么上述公式1返回“456”。其解析过程如下:

=0+MID(“ABC456”,MIN(FIND({0,1,2,3,4,5,6,7,8,9},“ABC456” & 1/17)),LEN(“ABC456”))

在A1后面添加1/17与在其后面添加字符串“0123456789”效果相同,详见《Excel公式技巧08. 17分之一和其他全数字(pandigitals)》。主要是必须将A1与包含0到9的所有数字的字符串连接起来,以防止MIN函数返回错误。因为如果A1不包含0-9的所有数字,那么FIND函数的返回值至少有一个是错误值,由于MIN函数不会忽略错误值,会导致整个公式的结果也是一个错误值。通过首先在A1中的字符串末尾添加一个适当的值(例如1/17、3^45,“0123456789”),可以保证该字符串将包含至少一个0-9中的每个数字(因此FIND函数的所有10个返回值都是非错误值),同时通过将字符串放在A1的末尾确保我们不会影响MIN函数所需的输出。

这样,现在上述公式转换为:

=0+MID('ABC456',MIN(FIND({0,1,2,3,4,5,6,7,8,9},'ABC456'&0.0588235294117647)),LEN('ABC456'))

可能你还不知道,在某些公式结构中,MIN函数具有强制返回数组的能力,且无需按Ctrl+Shift+Enter组合键。本例就属于这种情况,因此FIND函数将对传递给它的所有10个值进行操作,而不仅仅是对第一个值进行操作。因此,上述公式转换为:

=0+MID('ABC456',MIN({7,19,13,14,4,5,6,21,11,17}),LEN('ABC456'))

MIN函数返回字符串中数字开始的位置4,因此,上述公式转换为:

=0+MID('ABC456',4,LEN('ABC456'))

注意,MID函数(以及RIGHT函数和LEFT函数)具有一些有用的特性,当传递的参数num_chars的值大于要提取的实际字符串的长度时不会出错。也就是说,如果该参数的值将导致全部或部分返回值超出字符串末尾的情况时,则这些函数仅返回从指定位置到字符串末尾的那些字符。这里将参数num_chars的值指定为LEN(A1),因为没有子字符串的长度会大于字符串自身的情况。这样,上述公式转换为:

=0+MID('ABC456',4,6)

得到结果:

456

下面我们看看如果单元格A1中的字符串包含其它数字例如123ABC456,公式1是否有效。此时公式1转换为:

=0+MID(“123ABC456“,MIN(FIND({0,1,2,3,4,5,6,7,8,9},'123ABC4560.0588235294117647')),LEN(A1))

转换为:

=0+MID(“123ABC456“,MIN({10,1,2,3,7,8,9,24,14,20}),LEN(A1))

转换为:

=0+MID(“123ABC456“,1,LEN(“123ABC456“))

转换为:

=0+MID(“123ABC456“,1,9)

由于字符串中有其它数字的影响,导致找到的传递到MID函数的起始位置变化,因此结果为:

#VALUE!

LOOKUP与RIGHT

公式2:

=-LOOKUP(0,-RIGHT(A1,ROW(INDIRECT('1:'& LEN(A1)))))

这个公式与上一篇文章《Excel公式技巧10:从字符串中提取数字——数字位于字符串开头》中的公式1相似,只是使用RIGHT函数代替了LEFT函数。

当然,如果单元格A1中的字符串与“JAN18”、“123E4”类似,则不会返回正确的结果,详细原因参见上篇文章。

RIGHT、MATCH与ISNUMBER

公式3:

=0+RIGHT(A1,MATCH(FALSE,ISNUMBER(0+MID(A1,1+LEN(A1)-ROW(INDIRECT('1:'& LEN(A1))),1)),0)-1)

这是一个数组公式。

仍以单元格A1中的数据为“ABC456”,公式3可转换为:

=0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“ABC456”,1+6-ROW(INDIRECT('1:'& 6)),1)),0)-1)

转换为:

=0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“ABC456”,1+6-{1;2;3;4;5;6},1)),0)-1)

转换为(注意,这里是如何将得到的数组颠倒,从而使得从字符串的末尾到开头逐个获取字符成为可能):

=0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“ABC456”,{6;5;4;3;2;1},1)),0)-1)

转换为:

=0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+{6;5;4;C;B;A}),0)-1)

通过适当的数学运算(将数组与0相加),强制数字字符转换成数字:

=0+RIGHT('ABC456',MATCH(FALSE,ISNUMBER({6;5;4;#VALUE!;#VALUE!;#VALUE!}),0)-1)

ISNUMBER函数忽略传递给其参数中的错误值:

=0+RIGHT('ABC456',MATCH(FALSE,{TRUE;TRUE;TRUE;FALSE;FALSE;FALSE},0)-1)

转换为:

=0+RIGHT('ABC456',4-1)

其中的4表示在字符串“”中第一个非数字字符自右向左出现的位置,减1表示数字字符出现的位置:

=0+RIGHT('ABC456',3)

结果为:

456

下面,我们来看看字符串中除末尾以外的数字会不会影响最终的结果。例如如果单元格A1中的数据是“123ABC456”,那么公式3可以转换为:

=0+RIGHT(“123ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“123ABC456”,1+LEN(“123ABC456”)-ROW(INDIRECT('1:'& LEN(“123ABC456”))),1)),0)-1)

转换为:

=0+RIGHT(“123ABC456”,MATCH(FALSE,ISNUMBER(0+{“6”;”5”;”4”;”C”;”B”;”A”;”3”;”2”;”1”}),0)-1)

转换为:

=0+RIGHT(“123ABC456”,MATCH(FALSE,ISNUMBER(6;5;4;#VALUE!; #VALUE!; #VALUE!;3;2;1}),0)-1)

转换为:

=0+RIGHT(“123ABC456”,MATCH(FALSE,{TRUE;TRUE;TRUE;FALSE;FALSE;FALSE;TRUE;TRUE;TRUE},0)-1)

转换为:

=0+RIGHT('ABC456',4-1)

其中的4表示在字符串“”中第一个非数字字符自右向左出现的位置,减1表示数字字符出现的位置:

=0+RIGHT('ABC456',3)

结果为:

456

可以看到,由于是从右向左取数,因此在字符串的其它位置存在数字并不会影响结果。

RIGHT、MATCH与ISERR

公式4:

=0+RIGHT(A1,MATCH(1,0+ISERR(0+MID(A1,1+LEN(A1)-ROW(INDIRECT('1:'& LEN(A1))),1)),0)-1)

这是一个数组公式。

以单元格A1中的数据为“123ABC456”,公式4可转换为:

=0+RIGHT('123ABC456',MATCH(1,0+ISERR(0+{'6';'5';'4';'C';'B';'A';'3';'2';'1'}),0)-1)

转换为:

=0+RIGHT('123ABC456',MATCH(1,0+{FALSE;FALSE;FALSE;TRUE;TRUE;TRUE;FALSE;FALSE;FALSE},0)-1)

转换为:

=0+RIGHT('123ABC456',MATCH(1,{0;0;0;1;1;1;0;0;0},0)-1)

转换为:

=0+RIGHT('123ABC456',4-1)

转换为:

=0+RIGHT('123ABC456',3)

结果为:

456

与公式3一样,字符串中除末尾有数字外其它部位存在数字时不影响结果。

注:本技巧整理自excelxor.com,有兴趣的朋友可以研阅原文,特别是原文后面的评论。

excel取末尾数字_Excel公式技巧11: 从字符串中提取数字——数字位于字符串末尾...相关推荐

  1. python电话号码对应的字符组合_Python3 在字符串中提取字母+数字组合微信账号、电话等 - pytorch中文网...

    今天处理数据要提取字符串中的微信,字符串中包含中文英文Emoji,标点符号等. python 提取字符串中的电话 提取电话相对简单,多个电话也可以提取 import re desstr = " ...

  2. c语言如何将字符串中的数字提取出来,从含有数字的文本字符串中提取出数字...

    图1 可以使用数组公式: =1*MID(A1,MATCH(TRUE,ISNUMBER(1*MID(A1,ROW($1:$20),1)),0),COUNT(1*MID(A1,ROW($1:$20),1) ...

  3. [work] python从字符串中提取所有数字到list

    使用正则表达式,用法如下: 1 2 3 4 5 6 7 8 9 10 11 12 13 ## 总结 ## ^ 匹配字符串的开始. ## $ 匹配字符串的结尾. ## \b 匹配一个单词的边界. ##  ...

  4. Excel职场必备:从不规则字符串中提取手机号码的所有方法大全

    #excel技巧#运用Excel进行职场办公,我们会经常遇到这样的问题:如何从包含字母.汉字和符号的不规则字符串提取固定目标数字例如电话号码?熟悉Excel的小伙伴应该都了解常规的字符提取函数LEFT ...

  5. 使用 JavaScript 从字符串中提取数字

    在 JavaScript 中,有多种方法可以从字符串中提取数字.一种方法是使用 match() 方法和正则表达式来搜索字符串中的所有数字.另一种方法是使用 replace() 方法和正则表达式从字符串 ...

  6. MySQL字符串中提取数字

    问题描述: MySQL字符串中提取id数字,例:{"id":"11111","type":12,"attr":1} 思路 ...

  7. java替换最后一个字符_Excel公式技巧23: 同时定位字符串中的第一个和最后一个数字...

    学习Excel技术,关注微信公众号: excelperfect 在很多情况下,我们都面临着需要确定字符串中第一个和最后一个数字的位置的问题,这可能是为了提取包围在这两个边界内的子字符串.然而,通常的公 ...

  8. 从字母数字字符串中提取数字

    http://office.microsoft.com/zh-cn/excel-help/HA001154901.aspx 本文的作者是 Ashish Mathur,是一位 Microsoft MVP ...

  9. python3提取字符串中的数字_如何在Python中从字符串中提取数字?

    14 回复 | 直到 1 年前 1 430 3 年前 如果只想提取正整数,请尝试以下操作: >>> str = "h3110 23 cat 444.4 rabbit 11 ...

最新文章

  1. asp.net FileUpload随想随记
  2. 【Android View事件分发机制】关于拦截事件的注意点
  3. springboot幂等性_如何使用 SpringBoot + Redis 优雅的解决接口幂等性问题
  4. grid列的值格式化
  5. 抖音api开放平台对接_抖音新增酒店预订等功能,一只脚踏进美团、携程腹地
  6. OpenMAX IL介绍与其体系
  7. v8go 库手动编译 v8 golang 库手动编译
  8. R语言_安装包时联网失败
  9. jQuery - 不同版本的差异汇总(版本选择建议)
  10. 淘客帝国4.0免费版网页模板修改及n…
  11. Python进制转换
  12. app后端设计(6)-- LBS
  13. 常用算法简要总结(C语言)
  14. [TIM] 微信登录TIM生产QQ号【并独立使用】
  15. mysql select 补空行_用前一行的值填充空行mysql
  16. 【pd.to_datetime】时间object转换datetime实例
  17. 据说程序员写完代码是这个样子,99%的人都中枪了
  18. 重尾(heavy-tailed)、肥尾(fat-failed)、长尾(long-tailed)、次指数(subexponential)
  19. h5+app打开pdf,图片,excel,world(亲测可用)
  20. 如何给条码标签打印软件设置密码保护

热门文章

  1. Linux 进程通信 -- 管道
  2. 升级bigsur_2年内彻底摆脱英特尔,苹果重磅发布自研Mac芯片,并对“五大系统”再升级...
  3. 酷比魔方IWork1X 的做系统问题
  4. 分享一个超好用的批量处理PPT与PPTX转换,批量删除某一页PPT,批量DOC转换为DOCX的应用
  5. windows下安装禅道
  6. 并行计算求pi值C语言,使用并行计算求圆周率π.pdf
  7. 低功耗蓝牙ATT/GATT/Profile/Service/Characteristic解读
  8. Joplin+坚果云同步
  9. 关闭compactos_开启Compact压缩Win10系统文件,为Win10系统盘瘦身
  10. selenium报错信息-- Python 中 ‘unicodeescape‘ codec can‘t decode bytes in position XXX: trun错误解决方案