excel公式技巧同时定位字符串中的数字
发布时间:2022-12-21 16:08:14
在很多情况下,我们都面临着需要确定字符串中第一个和最后一个数字的位置的问题,这可能是为了提取包围在这两个边界内的子字符串。然而,通常的公式都是针对所需提取的子字符串完全由数字组成,如果要提取的数字中有分隔符(例如电话号码)则无法使用。当然,可以先执行替换操作来去掉字符串中的分隔符,这可能会更复杂些。
本文仅涉及被提取的字符串内包含唯一的数字子字符串的情况。
我们以示例来解。先看一下要提取的数字中没有分隔符的情形,例如在单元格A1中的字符串如下:
Account No. 1234567890: requires attention
显然,我们要提取出1234567890。
下面是我们曾经使用的一个公式:
=-LOOKUP(1,-(MID(A1,MIN(FIND({1,2,3,4,5,6,7,8,9,0},A1&1/17)),ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))))&”**0″))
注意,必须在MID函数生成的值的末尾添加“**0”,以保证能够在任何情况下都得到正确的结果。例如,如果单元格A1中的字符串是:
Account No. 12-Jun: requires attention
使用没有添加“**0”的公式:
=-LOOKUP(1,-(MID(A2,MIN(FIND({1,2,3,4,5,6,7,8,9,0},A2&1/17)),ROW(INDEX(A:A,1):INDEX(A:A,LEN(A2))))))
返回的结果不是12,而是43994,即日期2020-6-12对应的序数。连接字符串“** 0”后,确保类似于“12–Jun”的字符串变为“12–Jun**0”,这样Excel不会将它们认为数字。同样,这也适用于与科学记数法格式的数字相似的字符串。
当然,这样的字符串还必须具有使任何数字保持不变的特性。字符串“**0”等效于“E0”,即表示索引为0的科学计数法,与10 ^ 0一致,因此可保证以这种形式表示的任何数字都将是不变。可以在工作表中进行下列测试来验证:
=0+(147&”**0″)
返回147。
=0+(147&”**2″)
返回14700。
这种方式比“E0”更好,例如:
=-LOOKUP(1,-(MID(A2,MIN(FIND({1,2,3,4,5,6,7,8,9,0},A2&1/17)),ROW(INDEX(A:A,1):INDEX(A:A,LEN(A2))))&”E0″))
得到的结果是36689,因为提取的子字符串为“12-JunE0”,Excel认为是日期2000-6-12。并且,“E”在不同的环境中可能有不同的解释。
好了!下面让我们看看一个相似的例子,但要提取的子字符串数字中包含有分隔符:
Account No. 1-234-5678-90: requiresattention
使用上面给出的公式:
=-LOOKUP(1,-(MID(A1,MIN(FIND({1,2,3,4,5,6,7,8,9,0},A1&1/17)),ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))))&”**0″))
返回1,而不是我们想要的1-234-5678-90。
正如上文提出的,先删除分隔符并不是一件简单的事:
=-LOOKUP(1,-(MID(SUBSTITUTE(A1,”-“,””),MIN(FIND({1,2,3,4,5,6,7,8,9,0},A1&1/17)),ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))))&”**0″))
乍一看似乎可以,但返回的结果是1234567890。留给我们的是,如何在正确的位置重新插入分隔符?当然,如果所给字符串的格式是固定的,例如电话号码。然而,即便如此,使用多个REPLACE/SUBSTITUTE函数可能使公式更复杂。
本文寻找的是如何通过确定字符串中的第一个和最后一个数字来提取出子字符串的一种通用解决方案,而不管分隔符是什么、有多少,并且不需要执行替换操作。
在前面的一系列文章中,我们已经找到了一种非常合适的方法来确定字符串中第一个数字的位置,即MIN/FIND函数组合构造。然而,找到一种等效的用于确定字符串中最后一个数字的结构并不容易,能够实现这一点是关键。
对于MID函数的参数num_chars:
=MID(A1,MIN(FIND({1,2,3,4,5,6,7,8,9,0},A1&1/17)),[someconstruction])
假设希望避免[some construction]由两个单独的子句进行减法运算,其中一个是字符串内第一个数字的位置,另一个是最后一个数字的位置。我们首先查看一些确定字符串中最后一个数字的位置的公式结构,然后查看其中的哪一个(如果有的话)也可能有助于发现第一个数字的位置,这可能会很有用。下面是实现此目的的3种主要的公式结构:
公式1:
=MATCH(1,0/ISNUMBER(0+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1)))
公式2:
=LOOKUP(1,0/ISNUMBER(0+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1)),ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))))
公式3:
=MAX(IF(ISNUMBER(0+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1)),ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1)))))
其中,公式1和公式3是数组公式。
显然,最好的是公式1,因为它不需要重复ROW子句。但是,这样的构造还可以用于查找字符串中的第一个数字吗?如果不行,公式2可以吗?公式3呢?
我们先尝试减法运行,即使用确定最后一个数字位置的子句减去用于确定第一个数字位置的子句:
MATCH(1,0/ISNUMBER(0+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1)))-MIN(FIND({1,2,3,4,5,6,7,8,9,0},A1&1/17))
从而构成解决方案:
=MID(A1,MIN(FIND({1,2,3,4,5,6,7,8,9,0},A1&1/17)),1+MATCH(1,0/ISNUMBER(0+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1)))-MIN(FIND({1,2,3,4,5,6,7,8,9,0},A1&1/17)))
不错!但是,可以改进参数num_chars的构造吗?
一种方法是对上面给出的公式3:
=MAX(IF(ISNUMBER(0+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1)),ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1)))))
进行微小的调整。在2010年及以后的版本中,Excel提供了AGGREGATE函数,它不仅可使许多数组(CSE)结构转换为非CSE,而且还具有标准的CSE公式无法复制的其他优点。
与公式3等价的使用AGGREGATE函数的公式为:
=AGGREGATE(14,6,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1)))/ISNUMBER(0+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1)),1)
我们可以利用其来不只生成最大值或最小值,而是生成包含这两个值的数组。因此,构造公式:
=MMULT(AGGREGATE({14,15},6,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1)))/ISNUMBER(0+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1)),1),{1;-1})
转换为:
=MMULT({25,13},{1;-1})
其中的13和25分别代表字符串中第一个和最后一个数字的位置。
但是,其仍有一点缺陷,就是需要重复ROW结构。我们能否对此进行改进,找到不需要重复子句的公式构造?是的,可以使用:
MATCH(“*”,T(1/(1+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1))),{1,0})
这类似于AGGREGATE的结构,将一个数组传递给其参数,得到两个结果组成的数组。上面的公式转换为:
MATCH(“*”,T(1/(1+{“A”;”c”;”c”;”o”;”u”;”n”;”t”;””;”N”;”o”;”.”;””;”1″;”-“;”2″;”3″;”4″;”-“;”5″;”6″;”7″;”8″;”-“;”9″;”0″;””;”r”;”e”;”q”;”u”;”i”;”r”;”e”;”s”;””;”a”;”t”;”t”;”e”;”n”;”t”;”i”;”o”;”n”})),{1,0})
转换为:
MATCH(“*”,T(1/({#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;2;#VALUE!;3;4;5;#VALUE!;6;7;8;9;#VALUE!;10;1;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!})),{1,0})
转换为:
MATCH(“*”,T({#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;0.5;#VALUE!;0.333333333333333;0.25;0.2;#VALUE!;0.166666666666667;0.142857142857143;0.125;0.111111111111111;#VALUE!;0.1;1;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!}),{1,0})
转换为:
MATCH(“*”,{#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;””;#VALUE!;””;””;””;#VALUE!;””;””;””;””;#VALUE!;””;””;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!},{1,0})
可以看出,不是错误值的就是数字值。指定参数match_type的值为1将为提供数组中最后一个非#VALUE!的位置;为0将提供第一个非#VALUE!的位置。这样,上面公式转换成:
{25,13}
现在,可以将此数组传递给MMULT函数,以最终得出MID函数的参数num_chars参数的值。最终的公式为:
=MID(A1,MIN(FIND({1,2,3,4,5,6,7,8,9,0},A1&1/17)),1+MMULT(MATCH(“*”,T(1/(1+MID(A1,ROW(INDEX(A:A,1):INDEX(A:A,LEN(A1))),1))),{1,0}),{1;-1}))


猜你喜欢
- Word能够说是很多用户的最常用的文档工具,而我们在编辑Word文档的时候难免会不小心在页眉处添加一个水平的横线,这样十分的常影响美观,那么
- 在我们平常办公时会遇到需要将文件扫描到电脑上的情况,相信还有部分用户对于这一操作不是很熟悉,那么下面就以Win11系统为例,为大家带来Win
- win10预览版14332桌面回收站中文件不能删除怎么办?很多朋友升级win 14332预览版以后,发现回收站中的文件不能删除,这是怎么回事
- 升级了Windows8之后也是不能玩LOL,而Windows10也出现了一样的情况,win10不能玩lol怎么办?下面给出详细解决方案win
- 很多小伙伴在使用win7系统的时候,免不了有卡顿或者误删文件的情况,这个时候电脑无法正常的启动,选择恢复出厂设置选择项,今天小编带来了恢复出
- 想要查询在指定范围内的数据时,可以使用语句BETWEEN AND和NOT BETWEENAND。其中BETWEEN后是范围的下限,AND后面
- 这篇文章主要介绍了win7怎么恢复回收站已删除文件?Win7回收站删除恢复操作教程的相关资料,需要的朋友可以参考下本文详细内容。win7怎么
- 很多用户们都不清楚在使用火狐浏览器的时候,怎么样才能够将一些感兴趣的网址进行收藏等,今天就随小编详细看看这个问题的详细教程吧~火狐浏览器怎么
- Hosts文件通常用于补充或取代网络中DNS的功能,因此有不少用户都经常会去编辑Hosts文件,但最近有小伙伴在修改Hosts文件的时候发现
- 有的时候我们会在Excel表格中进行一些文字的排序,我们都知道,如果是数值排序的话,可以进行升序或直降雪来排列顺序,那么文字如何排序呢?今天
- Win10自带的OneNote知名度可能不及EverNote,但在功能上却并不落后给前者。今天小编向大家介绍Win10 OneNote绘图功
- 可能有很多小伙伴不是很清楚如何设置定时开关机?设置定时开关机的话可以帮助我们免去开关机的操作,那么具体是怎么设置的呢?下面一起来看看吧,希望
- wps演示是可以设置幻灯片自动播放的,你知道怎么做吗?下面小编就为你介绍wpsppt怎么样设置自动播放的方法啦!wpsppt设置自动播放的方
- 想要更有效的管理屏幕使用时间,通常设置密码是第一想法,尴尬的是密码太多忘记了,怎么办?别急小编今天的文章内容轻松帮您解决难题,方法简单上手神
- 一、SUMPRODUCT函数语法及功能SUMPRODUCT函数功能:计算工作表内多列中对应值相乘之后的和,即乘积之和。其语法为:SUMPRO
- 而在WPS 文字中,各种字体都有不同的、有意思的符号,比如:♠ ♡ ♣ ♤ ♥ ♧ ♨ ♩ ♪ ♬ ♭ ;看到这样的符号,是不是觉得很有意思
- 在日常使用win11系统的过程中,用户难免需要对电脑中一些无用的垃圾文件进行删除,防止过度占用电脑内存,不过有用户在进行win11系统无用文
- Windows 10拥有多种性能模式,不同的性能模式会消耗不同的电量、提供不同的性能。那Win10系统如何设置性能最好?下面就来看看正确的设
- 咪咕音乐如何更换彩铃?越来越多的人都开使用咪咕音乐这款软件,在里面我们可以设置很多炫酷的彩铃,如果我们想要更换彩铃,要怎么进行操作呢,下面就
- YouTube提供了大量的视频库,可以让我们微笑,傻笑,哭泣,或者能让我们解一下我们周围的世界。本教程小编将向您介绍如何在Mac上下载You