免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: hover_sky
打印 上一主题 下一主题

按照第一列,去掉重复数据的问题 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2011-10-20 12:56 |只看该作者
本帖最后由 ywlscpl 于 2011-10-20 12:58 编辑

对于连自己要什么都不清楚的楼主,须这样回答
t1.txt

dd:00
dd:01
ff:90
ff:80
dd:90

希望得到结果:
dd:00
ff:90


按照:分隔,分成2列,把第一列中每个不同的值,取出它在在t1.txt 中出现第一次的行的记录。

答案:awk -F: '!a[$1]++' t1.txt

数据

jj:00
dd:00
dd:01
ff:90
ff:80
dd:90
jj:01


显示的结果是
dd:00
ff:80
jj:00

我需要的是

jj:00
dd:00
ff:80


为什么你需要的是ff:80 ,而不是ff:90  (ff:90是出现于ff:80之前的)
因为你要的是按第2列排序后的第一行数据

ywlscpl@ubuntu:~$ awk -F: 'NR==FNR&&(!($1 in min)||$2<min[$1]){min[$1]=$2;l[$1]=$0}NR>FNR&&!a[$1]++{print l[$1]}' file file
jj:00
dd:00
ff:80

评分

参与人数 1可用积分 +2 收起 理由
waker + 2 不能太较真儿

查看全部评分

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
12 [报告]
发表于 2011-10-20 14:20 |只看该作者
楼上太认真了

论坛徽章:
0
13 [报告]
发表于 2011-10-20 14:33 |只看该作者
回复 12# waker


nod
再想了下也许8楼只是ff:90笔误成了ff:80
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP