免费注册 查看新帖 |

Chinaunix

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

awk从两个文件中筛选内容? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-07-08 16:30 |只看该作者 |倒序浏览
本帖最后由 bbyyzhang 于 2010-07-08 17:56 编辑

awk从两个文件中筛选内容? 升级了

file1.txt
1     aaa asd
12   bbb asd
2     ccc fds
34   ddd fsa

file2.txt
12   ddd fsa
3     aaa asd
4     bbb asd
5    ccc   gdf
怎么筛选出行
2    ccc fds


从$2到结束 是一个完整要判断的内容,不过内容有点复杂 多个空格
如果在$2之前加个 | 分隔符就可以加上-F参数就能用3楼的命令
  1. awk -F '|' 'FNR==NR{a[$2];next}{if(!($2 in a)) print}' file2 file1
复制代码
搞定了,不过不知道怎么加...
因为第一列是我这么搞出来的
  1. awk -F '"' '/xxx/ {print $6}' xxx_access_log|sort -k1|uniq -c >> aaa.txt
复制代码

论坛徽章:
0
2 [报告]
发表于 2010-07-08 16:37 |只看该作者
哪位大侠帮偶解答下啊,急用

论坛徽章:
0
3 [报告]
发表于 2010-07-08 16:37 |只看该作者
  1. awk 'FNR==NR{a[$2];next}{if(!($2 in a)) print}' file2 file1
复制代码

论坛徽章:
0
4 [报告]
发表于 2010-07-08 16:47 |只看该作者
本帖最后由 bbyyzhang 于 2010-07-08 18:00 编辑
lkk2003rty 发表于 2010-07-08 16:37

牛人啊,感激涕零

论坛徽章:
0
5 [报告]
发表于 2010-07-08 16:52 |只看该作者
学习了

论坛徽章:
0
6 [报告]
发表于 2010-07-08 17:32 |只看该作者
没看出规律,,,,,
awk 'FNR==NR{a[$2];next}{if(!($2 in a)) print}' file2 file1  无输出.

论坛徽章:
1
水瓶座
日期:2013-11-04 13:16:13
7 [报告]
发表于 2010-07-08 17:33 |只看该作者
回复 2# bbyyzhang


    我来个,分两步的
sed  -i  's/^[0-9 ]*//g' aa.txt

grep  -vf aa.txt  aaa.txt

有办法用个管道解决吗?

论坛徽章:
0
8 [报告]
发表于 2010-07-08 17:45 |只看该作者
本帖最后由 bbyyzhang 于 2010-07-08 17:55 编辑

从$2到结束 是一个完整要判断的内容,不过内容有点复杂 多个空格
如果在$2之前加个 | 分隔符就可以加上-F参数搞定了,不过不知道怎么加...
因为第一列是我这么搞出来的
  1. awk -F '"' '/xxx/ {print $6}' xxx_access_log|sort -k1|uniq -c >> aaa.txt
复制代码

论坛徽章:
0
9 [报告]
发表于 2010-07-08 17:59 |只看该作者
回复  bbyyzhang


    我来个,分两步的
sed  -i  's/^[0-9 ]*//g' aa.txt

grep  -vf aa.txt  aaa ...
howge 发表于 2010-07-08 17:33


哥你的办法有点暴力,把前面的数据给我弄没了

论坛徽章:
0
10 [报告]
发表于 2010-07-08 18:46 |只看该作者
  1. [oracle@s12071 ~]$ cat file1
  2. 1     aaa afd asdf13333342342342
  3. 12   bbb  fwerwr
  4. 2     cccf asf a  afdsf
  5. 34   ddd a 32 sdfsf
  6. [oracle@s12071 ~]$ awk '{$2="|"$2}1' file1
  7. 1 |aaa afd asdf13333342342342
  8. 12 |bbb fwerwr
  9. 2 |cccf asf a afdsf
  10. 34 |ddd a 32 sdfsf
  11. [oracle@s12071 ~]$
复制代码
没看懂第一列怎么出来的啥。。。。。。
只知道 给个文件  我加|
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP