免费注册 查看新帖 |

Chinaunix

广告
  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5395 | 回复: 14
打印 上一主题 下一主题

[文本处理] 关于grep匹配的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-05-17 18:05 |只看该作者 |倒序浏览
诸位好,请教个问题,在csh下,我用grep去做匹配,发现结果和我预想的有出入:
grep '([1-9]*)' file
输出结果中没有这两个结果:
LAYER AL_RDL ..... TOTAL Original Geometry Count = 8447    (10013)
TOTAL DRC Results Generated:     4311 (107274)
我的本意是想输出括号中不是0的结果,去掉类似于TOTAL DRC Results Generated:     0(0)这种。

换成另外一种方法:
grep '(*[1-9])' file
输出结果正确。

脚本倒是写好了,就是不明白为什么第一种匹配方法不行,我的理解是先匹配(,在匹配一个不是0的数字,然后匹配随意,最后匹配)。
但是不知道为什么没有实现,请不吝赐教。

论坛徽章:
2
狮子座
日期:2014-05-30 21:43:03巳蛇
日期:2014-05-30 21:46:14
2 [报告]
发表于 2014-05-17 18:23 |只看该作者
你就是想去除 不包含这个的行(0),是吧?
  1. fgrep -v "(0)"
复制代码
fgrep 是专门匹配非正则表达式的;
-v 是取反

论坛徽章:
6
摩羯座
日期:2013-08-24 10:43:10狮子座
日期:2013-08-25 10:27:06天秤座
日期:2013-09-11 20:28:44午马
日期:2014-09-28 16:06:0015-16赛季CBA联赛之八一
日期:2016-12-19 13:55:0515-16赛季CBA联赛之天津
日期:2016-12-20 14:01:23
3 [报告]
发表于 2014-05-17 20:48 |只看该作者
本帖最后由 cao627 于 2014-05-17 21:32 编辑
  1. $ echo 'LAYER AL_RDL ..... TOTAL Original Geometry Count = 8447    (10013)' | grep  '([0-9]*[1-9][0-9]*)'
  2. LAYER AL_RDL ..... TOTAL Original Geometry Count = 8447    (10013)

  3. $ echo 'LAYER AL_RDL ..... TOTAL Original Geometry Count = 8447    (0000)' | grep  '([0-9]*[1-9][0-9]*)'

  4. $ echo 'LAYER AL_RDL ..... TOTAL Original Geometry Count = 8447    (0000)' | grep -v '(0)'
  5. LAYER AL_RDL ..... TOTAL Original Geometry Count = 8447    (0000)

复制代码
$ echo 'LAYER AL_RDL ..... TOTAL Original Geometry Count = 8447    (10013)' | grep '(*[1-9])'
LAYER AL_RDL ..... TOTAL Original Geometry Count = 8447    (10013)

grep '(*[1-9])'   相当于 grep '([1-9])' 或  grep '[1-9])'

grep '[1-9])'  当然能匹配到   (10013)


论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
4 [报告]
发表于 2014-05-18 00:47 |只看该作者
([1-9]*)过滤的结果是括号里的数字不含0的结果

如果你只是想排除(0)这种情况,可以用-v参数:
  1. grep -v '(0)' file
复制代码

论坛徽章:
0
5 [报告]
发表于 2014-05-18 00:50 |只看该作者
正则表达式中的*并非表示匹配任意字符,而是之前的结构出现任意次(包含0次)。
正则表达式中的?并非表示匹配单个字符,而是之前的结构出现0或1次。
正则表达式中的+表示之前的结构出现至少1次,与*的差别在于不可匹配到0次。
正则表达式中使用.来匹配大多数字符,.*常用来匹配任意字符。

论坛徽章:
0
6 [报告]
发表于 2014-05-18 10:49 |只看该作者
回复 2# tgwz88
多谢,我顺便明白了fgrep。文档中说的是:允许查找字符串而不是一个模式。看的我云山雾罩的,原来是不支持正则表达式。

   

论坛徽章:
0
7
发表于 2014-05-18 10:52
回复 5# 用户名注册后不能更改
多谢,朋友解释的非常清楚。


   

论坛徽章:
0
8 [报告]
发表于 2014-05-18 10:53 |只看该作者
回复 4# yestreenstars
多谢!


   

论坛徽章:
0
9 [报告]
发表于 2014-05-18 11:22 |只看该作者
回复 3# cao627
感谢朋友的详细解释,其实我这种匹配还是有问题。如果括号内末尾为0,就匹配不出来。
echo 'LAYER AL_RDL ..... TOTAL Original Geometry Count = 8447    (100130)' | grep '(*[1-9])'
所以用了几位所说的方法 grep -v '(0)' 或者grep '([1-9]+)'

还是有个疑问。您所说的grep '(*[1-9])'   相当于 grep '([1-9])' 或  grep '[1-9])'
为什么会相当于grep '[1-9])'呢?




   

论坛徽章:
0
10 [报告]
发表于 2014-05-18 11:24 |只看该作者
本帖最后由 winteryxu 于 2014-05-18 11:50 编辑

回复 5# 用户名注册后不能更改
多谢,我已经用egrep '([1-9]+)' 解决。
用grep  '([1-9]+)' 不行。
   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP