Excel 分离字符串数的文字、数字、字母
前言
工作中时常需要从字符串中分离文字、数字、字母,对于有明显组成规则的数据,可以用mid,right,left等公式解决,而对于不规则的数据又该怎么解决呢?
在此记录,积累。
一、从规则数据中分离文字、数字、字母
观察到A列数据依次由2个文字、2个字母、3个数字组成,用mid,right,left等公式分离:
在B2输入公式: =LEFT(A2,2)
【释义】提取A2单元格左数前2个字符
在C2输入公式: =MID(A2,3,2)
【释义】提取A2单元格第3个字符起,数2个字符
在D2输入公式: =RIGTH(A2,3)
【释义】提取A2单元格右数前3个字符
下拉填充公式,完成分离。
二、从不规则数据中分离文字、数字、字母
A列数据由文字、字母、数字依次组成,但各自数量不规则
1.分离文字
在B2输入公式: =LEFT(A2,LENB(A2)-LEN(A2))
【释义】
LENB(A2),返回A2的字节数(一个文字2个字节,数字和字母1个字节),返回值为10
LEN(A2),返回A2的字符数,返回值为8
LENB(A2)-LEN(A2),求得A2中的文字数,返回值2
2.分离数字
在C2输入公式: =MID(A2,IFERROR(SEARCHB("?",A2),""),LEN(A2))
【释义】
SEARCHB("?",A2),返回A2中首次出现数字的位置
IFERROR,错误判断,但当A2中无数字时,SEARCHB("?",A2)会报错,IFERROR会捕捉错误并返回我们设定的值,设定值为""
3.分离字母
在D2输入公式: =SUBSTITUTE(SUBSTITUTE(A2,B2,""),C2,"")
【释义】
SUBSTITUTE作用:选定字符串,将其中某部分旧字符串替换为新字符串
这里我们将文字和数字(B2,C2)替换为空值"",便分离出了字符串中得字母。
总结
1、区分 LENB 和 LEN,前者返回字节位置,后者返回字符位置,类似的还有FINDB FIND,LEFTB LEFT, MIDB MID 等等;
2、文字2字节,数字和字母1字节;
3、SUBSTITUTE作用:选定字符串,将其中某部分旧字符串替换为新字符串;