excel字符串设置
发布时间:2023-09-25 17:31:58
上篇文章解了提取位于字符串开头的数字的公式技术,本文研究从字符串开头提取数字的技术:
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”效果相同。主要是必须将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从字符串中提取数字——数字位于字符串开头》中的公式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一样,字符串中除末尾有数字外其它部位存在数字时不影响结果。


猜你喜欢
- 微软于今天推送了Windows10 PC秋季创意者更新快速预览版16278,今天小编为大家带来了PC快速预览版稳定性提升和问题修复内容,希望
- Win10系统打开图片时默认由照片应用打开,但是这个照片应用经常要加载很久而且不好用,下面给大家分享将图片打开方式修改为照片查看器的操作方法
- 大家可能更喜欢用usb来进行启动安装的方法,这个方法从较早的usb安装盘开始就一直在用。那么win10的usb启动设置跟之前的系统一样吗,会
- 我们在玩游戏的时候经常会使用到FPS来检测自己的实时游戏的网速情况。最近十分火热的赛博朋克2077要怎么设置显示FPS呢?许多玩家在玩赛博朋
- 在制作完excel表格以后,如果发现表中的某行内容是多余的,可以将其删除,同时列也是一样可以删除的,但是我们在删除的时候要注意是否包含运算公
- Win10系统下的很多程序都会有菜单栏,比如说记事本的标题栏下的就是菜单栏,菜单栏可以随着记事本宽度的调整而变化,那么如何手动修改Win10
- 反编译软件Hopper Disassembler for Mac十六进制模式的介绍分享给大家,Hopper Disassembler for
- 我们在使用wps文字编辑文档的时候,经常会用到替换功能,那么,如何使用该功能呢?下面就让小编告诉你wps如何使用替换功能。wps使用替换功能
- 许多用户在使用电脑的时候经常会出现各种各样的问题。例如最近就有小伙伴在使用电脑的时候电脑突然弹窗提示windows找不到文件请确定文件名是否
- 如何在WPS默认表格中修改大小?新手不会,上网找怕麻烦,而且教程太乱没有统一的答案怎么办,哪里有更好的方法?下面小编马上就告诉大家怎么做。W
- 有些人问小编win10无法被远程连接是什么意思?win10无法被远程连接是怎么回事?这就不知道啦吧!下面就让小编给大家介绍一下关于win10
- 对于一张数据表格来说,我们通常需要对其进行数据的筛选,那么,如何使用手机wps表格筛选数据呢?下面就让小编告诉你如何使用手机wps表格筛选数
- Word是我们日常工作中使用最普遍的文档处理工具之一,但是很多朋友在使用时对碰到的文档出错,常常无计可施。难道只能眼睁睁的看着急需的文档无法
- 现在有很多用户在使用电脑的时候都喜欢去连接各种蓝牙设备,但最近也有部分用户在使用蓝牙设备的过程中发现无法在win10进行连接了,那么遇到这种
- Win7笔记本合盖后唤醒不了怎么办?正常情况下,如果电脑处于使用状态,当我们合上盖子,可以节省电源,再次想用时只要按下电源按钮即可启动。但是
- 我们在使用excel过程中,有时设置很多颜色为了区分,但是打印的时候又想要设置单色打印,该如何设置呢?下面小编就带大家来了解一下在日常工作中
- 今天,在公众平台,有一位男士提出这样一个问题:他那可爱的老婆,做微商,学着用EXCEL做买卖记录,今天拿出记录表让他帮着计算现有的存货,这位
- Win10系统可以说是最常用的系统之一,但是随着使用时间越长,碰到的问题就越多,有的小伙伴就碰到自己电脑中的设备无法打开,那么遇到这种情况应
- 脱机有很多种可能,其中最常见的有以下四种:驱动虚拟端口错误脱机打印机电源未开脱机数据线及物理端口损坏脱机主板芯片损坏脱机如果是第一二三种那很
- 阅读星APP怎么导入书籍?阅读星一款个性化阅读软件,用户可以在里面下载、观看小说。那么阅读星APP该如何导入书籍呢,下面就给大家分享阅读星A