免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: a475772910

[文本处理] 求帮忙!!!急 [复制链接]

论坛徽章:
0
发表于 2013-04-20 16:10 |显示全部楼层
本帖最后由 a475772910 于 2013-04-20 16:13 编辑

回复 10# shijiang1130

抱歉我还是没说明白{:3_188:}
    是这样子  只要 第三列和第四列 有一样的数 (不一定非在同一行)  就可以提出来那写一样的数所在的行   如下:
  

    111 222 111 333
    111 222 333 444
    111 222 222 777


变为
    111 222 111 333
    111 222 333 444

论坛徽章:
0
发表于 2013-04-20 16:11 |显示全部楼层
本帖最后由 a475772910 于 2013-04-20 16:12 编辑

回复 10# shijiang1130


    如果按你例子写的就是所有的都符合  因为001 和002 中都含有333

论坛徽章:
0
发表于 2013-04-20 16:47 |显示全部楼层
回复 11# a475772910

楼主,你的表述是否如下:

对于任意一行,若其中的第三列或第四列与其它任意一行的第三列或第四列的数据有相同,则这两行数据应该被保留下来。

论坛徽章:
0
发表于 2013-04-20 17:36 |显示全部楼层
这样?
  1. # awk 'NR==FNR{a[$3];b[$4];next}{if(($3 in b)||($4 in a)) print $0}' ufile.txt  ufile.txt                        
  2. 789  89  555  66
  3. 855  75  66    77
  4. 859  88  777  23
  5. 962  74  23    100
复制代码

论坛徽章:
0
发表于 2013-04-20 19:48 |显示全部楼层
回复 14# pipe55_cu


{:3_193:}{:3_193:}{:3_193:}    多谢大神帮助  小弟佩服

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
发表于 2013-04-20 20:22 |显示全部楼层
a475772910 发表于 2013-04-20 19:48
回复 14# pipe55_cu
  1. $ awk '{a[$0]=$3;b[$0]=$4}END{for(i in a){for(j in b)if(a[i]==b[j]){print i"\n"j}}}' a.txt
  2. 855  75  66   77
  3. 789  89  555  66
  4. 962  74  23   100
  5. 859  88  777  23
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP