AB1-C#AB2-D#E#EF,怎样用公式提取#前后的不规则字符?

AB1-C#AB2-D#E#EF,怎样用公式提取#前后的不规则字符?

码农世界 2024-05-23 前端 66 次浏览 0个评论

用那个经典的TRIM+MID+SUBSTITUTE+REPT+ROW/COLUMN函数组合吧,示例将以下字符串分拆到B:F列:

一、公式

B2=TRIM(MID(SUBSTITUTE($A2,"#",REPT(" ",100)),COLUMN(A2)*100-99,100))

向下、向右填充公式。

二、公式解析

REPT(" ",100),重复空格100次,生成一个由100个空格组成的字符串。

COLUMN(A2)*100-99,随着公式向右填充,生成一个1,101,201,301.……的序列。

SUBSTITUTE($A2,"#",REPT(" ",100)),将A列字符串中的“#”替换成100个空格的字符串,替换完成后,需要的字符就变成有用字符由100个空格连接起来的更长的字符串。

MID函数,将SUBSTITUTE替换后的字符串,从第1个字符开始提取100个字符,随着公式向右填充,将从101、201、301……字符开始提取100个字符,提取出的100个,由需要的字符左右两侧连接了数量不等的空格组成,然后用TRIM函数将左右两侧的空格清除掉,剩下的就是需要的字符了。

三、注意事项

1.这里面最后是清除空格,因此如果需要的数据里用空格,就不能用SUBSTITUE、TRIM空格了,可以使用一个不会出现的字符比如本例中,也可以用“@”,公式写为

=SUBSTITUTE(MID(SUBSTITUTE($A2,"#",REPT("@",100)),COLUMN(A2)*100-99,100),"@","")

添加图片注释,不超过 140 字(可选)

2.如果需要的字符比较长,要酌情将公式中REPT和SUBSTITUTE函数所用的100放大,如1000、10000……,以免字符度累加后造成公式出错。

转载请注明来自码农世界,本文标题:《AB1-C#AB2-D#E#EF,怎样用公式提取#前后的不规则字符?》

百度分享代码,如果开启HTTPS请参考李洋个人博客
每一天,每一秒,你所做的决定都会改变你的人生!

发表评论

快捷回复:

评论列表 (暂无评论,66人围观)参与讨论

还没有评论,来说两句吧...

Top