免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 12601 | 回复: 22
打印 上一主题 下一主题

awk+sed删除文件中匹配的行 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-22 12:01 |只看该作者 |倒序浏览
我想在一个文件中利用awk按照第一列和第二列的值进行匹配,然后将匹配到的行从原文件中删除,
有人帮我用awk+sed实现吗??

多谢了!

本人是新手,请多多关照。。。

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
2 [报告]
发表于 2009-05-22 12:34 |只看该作者

论坛徽章:
0
3 [报告]
发表于 2009-05-22 12:44 |只看该作者
给个例子吧。

论坛徽章:
0
4 [报告]
发表于 2009-05-22 12:52 |只看该作者

  1. sed -ir '/([^ \t]+)[ \t]+\1/d' URFILE
复制代码

论坛徽章:
0
5 [报告]
发表于 2009-05-22 13:25 |只看该作者

回复 #3 我是DBA 的帖子

MON=Jan
DAY=1
for file in /home/log/*;
do         
        awk '{if($1 = "'$MON'" && $2 = "'$DAY'"){删除该行}}' $file  
done

好像if里面的判断语句目前也有点问题,因为只按MON进行了匹配。。
删除该行的操作不知道能不能通过调用sed来实现? 或者有其他的方法吗?

论坛徽章:
0
6 [报告]
发表于 2009-05-22 13:30 |只看该作者
to me : 事实证明猜测总是自作聪明…… - -

$1 = "'$MON'",这是赋值语句,不是对比语句,换成$1 == "'$MON'"。

如果直接修改原文件,awk这行可换成:

  1. sed -i "/^$MON[ \t]+$DAY/d" $file
复制代码

论坛徽章:
0
7 [报告]
发表于 2009-05-22 13:44 |只看该作者

回复 #6 kwokcn 的帖子

多谢6楼的。。  我还在想这个问题的。。 正在看awk相关的语法呢。。

再次感谢!!!

论坛徽章:
0
8 [报告]
发表于 2009-05-22 16:38 |只看该作者

回复 #6 kwokcn 的帖子

稍微改动了一下。。。

for file in /home/log/*;
do         
        sed -i "/^$MON[\t ]*$DAY/d" $file  
done

删除以MON开头+任意空格+DAY的行

论坛徽章:
0
9 [报告]
发表于 2009-05-22 17:07 |只看该作者
原帖由 aeoluschi 于 2009-5-22 16:38 发表
稍微改动了一下。。。

for file in /home/log/*;
do         
        sed -i "/^$MON[\t ]*$DAY/d" $file  
done

删除以MON开头+任意空格+DAY的行

貌似只有[]里面" "和"\t"的位置调换了一下…… - -

论坛徽章:
0
10 [报告]
发表于 2009-05-22 17:45 |只看该作者
原帖由 kwokcn 于 2009-5-22 17:07 发表

貌似只有[]里面" "和"\t"的位置调换了一下…… - -

+ 变成了 ×, 估计你当时写的时候笔误~。~
又让我看了半天语法。。 呵呵
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP