IC库存_LED灯_FPC连接器

IC库存_LED灯_FPC连接器
当前位置: IC网站 > IC Datasheet >

从Excel中混合数字与字母字符串中提取连续数字的方法

时间:2013-08-22 17:13来源:gongwin.com 作者:省芯商城 点击:
从Excel中混合数字与字母字符串中提取连续数字的方法
第二种方案是提取连续数字:
FIND函数——查询文本所在位置
FIND(find_text,within_text,[start_num])
FIND(需查找的文本,包含查找文本的单元格,开始查找单元格的字符位置(可选))
此处FIND函数是搜索{1,2,3,4,5,6,7,8,9,0}数字在“A1&1234567890”中所在的位置;
A1&1234567890的目的是在用FIND函数查询时,不出现错误值,使之后的MIN函数可以正常运行。
即FIND({1,2,3,4,5,6,7,8,9,0},“小王联系电话58670098负责财务1234567890”)
选取划黑后按F9,得出的位置为:{19,20,21,22,7,9,10,8,13,11}


MIN函数——返回列表中的最小值
MIN(number1,number2,……)
MIN(数字1,数字2,……)
将FIND所得结果{19,20,21,22,7,9,10,8,13,11}带入MIN函数,最小值所得为7,正是第一个数值出现的位置;
也正是之前FIND函数中使用A1&1234567890的原因。


MID函数——返回文本字符串从指定位置开始特定数目的字符,即提取某段字符。
MID(text,start_num,num_chars)
MID(被提取的文本或单元格,开始提取的字符位置,提取的字符个数)
将上述MIN函数所得带入MID(A1,7,ROW($1:$8);
ROW($1:$8)使用row函数不是用来计算行,而是借用其作为常量。当然1:8是可以修改的,只要大于数值个数就不影响结果。


--MID(……)中“--”的作用是将MID得出的结果变为数值,使其可以被LOOKUP函数查询到。
MID(……)选取划黑后按F9{"5";"58";"586";"5867";"58670";"586700";"5867009";"58670098"}
--MID(……)选取划黑后按F9{5;58;586;5867;58670;586700;5867009;58670098}


LOOKUP函数——从返回某个查询的值(数组形式)
LOOKUP(lookup_value,array)
LOOKUP(在数组中查找的值,数组范围区域)
很重要的一点:
如果 LOOKUP 找不到 lookup_value 的值,它会使用数组中小于或等于 lookup_value 的最大值。
LOOKUP(9E+307,……)其中9E+307指的是一个不会出现的超大值,9后面有307个0, 9E+307又可以写成9*10^307;那么此处搜索这个超大值,肯定无法找到,因此返回的内容将是小于或等于{5;58;586;5867;58670;586700;5867009;58670098}的最大值,即58670098。

公式:
=LOOKUP(9E+307,--MID(A1,MIN(FIND({1,2,3,4,5,6,7,8,9,0},A1&1234567890)),ROW($1:$8)))




第二种方案是提取所有数字:
此解决方案的基本原理是搜索并返回字母数字字符串中的第一个数字,然后只返回其后的数字。

  算法

  此解决方案包括创建公式以完成下列任务:

  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)

  将存储为文本的数字转换成数字之后,可以通过使用COUN 函数对其进行计数。可通过输入以下公式计算数字的数量:=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乘以整个公式。 (责任编辑:www.gongwin.com)
分享到: 更多
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------