Excel教程:提取手机号码,这是最好用的方法! 您所在的位置:网站首页 excel如何快速生成手机号 Excel教程:提取手机号码,这是最好用的方法!

Excel教程:提取手机号码,这是最好用的方法!

2023-05-25 22:50| 来源: 网络整理| 查看: 265

看来遇上这么复杂的数据,号称智能填充的Ctrl+E大法也失灵了,怎么办?

VBA……

完全不会呀,那么还有救么?

其实还真有一个公式可以解决这个问题,公式为:

结果如图所示:

公式看起来不是很长,但却使用了五个函数进行组合,下面就来破解这个公式的原理。

要解决问题首先要找到规律,手机号的一个特点就是长度为11位,并且全部都是数字,因此可以利用提取数字的套路来解决问题。

与通常提取数字的问题不同之处在于,在这些订单信息中,手机号码出现的位置不固定,并且会有其他的数字干扰,唯一可以利用的就是11位的数字这一点。

这就需要用到MID函数,格式为:MID(A2,1,11),意思是从A2单元格中的第一个字开始,截取11个字,公式结果为:

这一点很好理解,由于不确定手机号的开始位置,用一个常用的套路,就是将MID函数的第二参数使用ROW来实现多次提取的效果,为了便于理解,先用ROW(1:10)作说明。

来看看公式=MID(A2,ROW(1:10),11)的效果:

这样看着没什么区别,但是通过F9功能查看后就会发现,得到了10个截取后的内容:

这个公式相当于MID(A2,1,11)、MID(A2,2,11)……MID(A2,10,11)的效果。

为了能够提取出手机号,我们必须将MID的第二参数继续放大,习惯上都使用ROW(1:99)这种写法,再来看看效果:

可以看到手机号确实在这一大串字符中。

到这一步,手机号成功的被截取出来了,接下来就是如何从这一组字符串中得到需要的手机号。

9E307表示一个非常大的数字,在MID前加“--”表示将截取的内容转为数字,这个公式的原理在之前的教程中也多次做过讲解。

可是公式得到的结果却让人大跌眼镜:

这是因为LOOKUP函数得到的是最后位置出现的数字,在案例中的数据中,除了手机号,后面还出现了订单时间,因此要想得到最终结果,还需要最后一个步骤,缩小LOOKUP处理的范围。

再次观察数据源,可以发现一个规律,手机号都是在“收货人”之前的位置,因此只需要把收货人前面的字符串提取出来,再用刚才的公式就能得到结果。

这个很容易实现,利用LEFT+FIND组合就能完成,公式为:=LEFT(A2,FIND("收货人",A2)),结果如图所示:

关于LEFT+FIND组合比较好理解,如果有问题可以留言,我们会将类似的几个常用组合整理一篇教程。

结果出现错误值说明订单信息中没有手机号码。

总结:关于这个公式的原理为大家进行了分析,从今天这个案例中,可以了解到如何拆分一个看上去很复杂的问题,方法就是一点一点找规律,规律性越强,解决思路就越多。

其实这个问题还有另外一个思路,就是用公式:

有兴趣的伙伴可以试试自己分析一下公式的原理,当然也可以留言,看大家的需要,就这个公式再讲一次。

想要全面系统学习Excel,不妨关注部落窝教育的《一周Excel直通车》视频课或者《Excel极速贯通班》。

主讲老师: 滴答返回搜狐,查看更多



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有