excel表中,有一列数值,01.01.01,01.01.02 ,01.01.02.0001,01.01.03,01.01.03.0001,只想过滤出具有x

只过滤xx.xx.xx这种格式的,... 只过滤xx.xx.xx这种格式的, 展开
 我来答
new2cn
2010-08-22 · TA获得超过497个赞
知道小有建树答主
回答量:207
采纳率:0%
帮助的人:191万
展开全部
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也可以全部整合到一个列中去。

请给分,谢谢
hw17f
2010-08-17 · TA获得超过6.7万个赞
知道大有可为答主
回答量:7886
采纳率:45%
帮助的人:3061万
展开全部
在次列输入公式(假设在A列,就在在B列输入公式)

=if(len(a1)=8,"OK","NO")

对B列进行自行筛选或者排列均可。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式