_ __
1、首先要分析数据内容,根据不同的类型,使用不同的方法。
2、分析这个表格,可以发现,除了数字外,就是汉字,在双字节字符中,每个汉字算两个字节,利用此特点,可以算出有多少个汉字、多少个数字,单字节字符数用len函数:=len(a2)。
3、双字节字节数用lenb函数,注意下两者的区分,单字节指字符个数,双字节指字节个数:=lenb(a2)。
4、二者相减,即可得到文字的个数:=lenb(a2)-len(a2)。
5、再用总字符数减去文字个数,即得到要提取出来的数字个数:=len(a2)-(lenb(a2)-len(a2)),去掉括号,合并起来,公式为:=len(a2)*2-lenb(a2)。
6、知道了数字个数,再知道数字开始的位置,就可以用mid函数将数字提取出来了,但是现在不知道数字是从什么位置开始的,可以使用searchb双字节查找函数 通配符?来查询单字节出现的位置:=searchb(?,a2)。
7、这样提取公式就有了,提取函数也要用双字节函数:=midb(a2,searchb(?,a2),len(a2)*2-lenb(a2)),如果用单字节函数也可以,但公式稍长些:=mid(a2,int(searchb(?,a2)/2) 1,len(a2)*2-lenb(a2))。
8、提取结果是文本格式,如果要转为常规的数字格式,可以在公式前加上--,或者*1,来转换:=--midb(a2,searchb(?,a2),len(a2)*2-lenb(a2)),转换格式后,可以进行下一步的统计运算。
9、如果文字中有空格,直接提取就会出去,需要对原来的内容进行去空格替换后,再提取:=--midb(substitute(a2, ,),searchb(?,substitute(a2, ,)),len(substitute(a2, ,))*2-lenb(substitute(a2, ,)))。
10、但是上面的方法,只能用于除了数字就是文字的内容提取,如果除此之外,还有其它的字母、符号等单字节字符,就会出错。
11、对于这种不定型的,可以用数组公式进行提取,从每个字符开始,取出1~若干个字符(比如10个),再加上运算符号进行判断,取出的是不是数值,再用max函数从中取出是数值的*多数字:=max(iferror(--mid(a2,row($1:$30),column($a:$j)),)),在输入数组公式时,需要同时按住ctrl shift enter结束公式编辑,公式会自动生成一对“{}”。
12、当然,也可以不用上面的数组公式,利用lookup函数的向后兼容性,来提取出数字:=-lookup(1,-mid(a2,min(find({0,1,2,3,4,5,6,7,8,9},a2