excel表中,有一列数值,01.01.01,01.01.02 ,01.01.02.0001,01.01.03,01.01.03.0001,只想过滤出具有x
2个回答
展开全部
xx.xx.xx这种格式有三个特点,我们编辑公式必须按这三点来
1、全长=8,也就是len()的结果是8
2、中间有2个点来隔开成三段,换句话说,位置三和六取出来必须是点,而不是数值
3、每一段长度为2,且是数值
所以设计公式上可以有2个办法,1个办法是新建三列,每一列对应上面3个来设计,如果满足要求就显示1否则0,新建第四列,用IF函数收集三列值,如果全为1,则结果是我们需要的
列A 为原始数据 01.01.01
列B =IF(LEN(A1)=8,1,0) '判断是不是8位
列C =IF(MID(A1,3,1)&MID(A1,6,1)="..",1,0) '取3、6位判断吧是不是2个点
列D =IF(TEXT(VALUE(MID(A1,1,2)),"00")=MID(A1,1,2),1,0)*IF(TEXT(VALUE(MID(A1,4,2)),"00")=MID(A1,4,2),1,0)*IF(TEXT(VALUE(MID(A1,7,2)),"00")=MID(A1,7,2),1,0) '这个就要复杂一些了
列D我们分隔开来看,先看前面一段IF(TEXT(VALUE(MID(A1,1,2)),"00")=MID(A1,1,2),1,0),这段的作用是将1、2位取出后转化成数值,再将数值转化成字符,再用这个字符与原始的1、2位字符对比,如果1、2位其中一个不是数字而是其他任何东西,就会让IF函数为0。接下来是3、4位和7、8位,再三段相乘,如果乘积为1,才是三段均为纯数字 。
不要小看列D,比如说01.0a.01或者是01.0..01这样的都会被判断出来不符合。
列E就是结论: =IF(B1+C1+D1=3,"满足","")
我之所以要分成四列来写就是为了让大家看清楚过程,LZ也可以全部整合到一个列中去。
请给分,谢谢
1、全长=8,也就是len()的结果是8
2、中间有2个点来隔开成三段,换句话说,位置三和六取出来必须是点,而不是数值
3、每一段长度为2,且是数值
所以设计公式上可以有2个办法,1个办法是新建三列,每一列对应上面3个来设计,如果满足要求就显示1否则0,新建第四列,用IF函数收集三列值,如果全为1,则结果是我们需要的
列A 为原始数据 01.01.01
列B =IF(LEN(A1)=8,1,0) '判断是不是8位
列C =IF(MID(A1,3,1)&MID(A1,6,1)="..",1,0) '取3、6位判断吧是不是2个点
列D =IF(TEXT(VALUE(MID(A1,1,2)),"00")=MID(A1,1,2),1,0)*IF(TEXT(VALUE(MID(A1,4,2)),"00")=MID(A1,4,2),1,0)*IF(TEXT(VALUE(MID(A1,7,2)),"00")=MID(A1,7,2),1,0) '这个就要复杂一些了
列D我们分隔开来看,先看前面一段IF(TEXT(VALUE(MID(A1,1,2)),"00")=MID(A1,1,2),1,0),这段的作用是将1、2位取出后转化成数值,再将数值转化成字符,再用这个字符与原始的1、2位字符对比,如果1、2位其中一个不是数字而是其他任何东西,就会让IF函数为0。接下来是3、4位和7、8位,再三段相乘,如果乘积为1,才是三段均为纯数字 。
不要小看列D,比如说01.0a.01或者是01.0..01这样的都会被判断出来不符合。
列E就是结论: =IF(B1+C1+D1=3,"满足","")
我之所以要分成四列来写就是为了让大家看清楚过程,LZ也可以全部整合到一个列中去。
请给分,谢谢
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |