免费注册 查看新帖 |

Chinaunix

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

关于sort的一个问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-04-07 11:05 |只看该作者 |正序浏览
文件file内容如下:
uucp:5:5:UUCP administrator:/usr/lib/uucp:
uucp:6:2:UUCP administrator:/usr/lib/uucp:
uucp:5:3:UUCP administrator:/usr/lib/uucp:
uucp:6:1:UUCP administrator:/usr/lib/uucp:

sort -t: -k3n,3 file 的结果如下:
uucp:5:3:UUCP administrator:/usr/lib/uucp:
uucp:5:5:UUCP administrator:/usr/lib/uucp:
uucp:6:1:UUCP administrator:/usr/lib/uucp:
uucp:6:2:UUCP administrator:/usr/lib/uucp:

请问各位高手,为什么已经用-k3n,3指定只用第三个域进行排序,sort仍然对第四个域进行了排序?如何才能指定只按第三个域排序?

论坛徽章:
0
13 [报告]
发表于 2009-04-13 18:17 |只看该作者
原帖由 ywlscpl 于 2009-4-13 17:38 发表


稍微解释一下:
1、先根据域3值排序生成一个uniq的列表 FNR{print a[$1]}
4、最终实现仅按域3排序且域3值相同的行不打乱原始顺序。


謝謝 ywlscpl 大大.
這個我要慢慢消化一下 :wink:
努力中...

论坛徽章:
0
12 [报告]
发表于 2009-04-13 17:38 |只看该作者

回复 #11 惠繪洋 的帖子

awk -F ":" 'NR==FNR{a[$3]=(a[$3]?a[$3]"\n"$00)}NR>FNR{print a[$1]}' file <(awk -F ":" '{b[$3]=1}END{for (j in b) print j}' file|sort -n)


稍微解释一下:
1、先根据域3值排序生成一个uniq的列表 <(awk -F ":" '{b[$3]=1}END{for (j in b) print j}' file|sort -n)
2、NR==FNR{a[$3]=(a[$3]?a[$3]"\n"$00)会产生以域3值为下标的数组,数组内容为原始排序顺序的相应行内容
3、根据1中列表打印相应数组内容NR>FNR{print a[$1]}
4、最终实现仅按域3排序且域3值相同的行不打乱原始顺序。

[ 本帖最后由 ywlscpl 于 2009-4-13 17:46 编辑 ]

论坛徽章:
0
11 [报告]
发表于 2009-04-13 17:28 |只看该作者
原帖由 ywlscpl 于 2009-4-7 12:19 发表
awk -F ":" 'NR==FNR{a[$3]=(a[$3]?a[$3]"\n"$00)}NR>FNR{print a[$1]}' file  


你好,請教了.
我是shell 的新手. 這個指令太牛了. 能解識一下嗎??
學習中.

謝謝.

论坛徽章:
0
10 [报告]
发表于 2009-04-13 10:21 |只看该作者
原帖由 ywlscpl 于 2009-4-7 12:19 发表
awk -F ":" 'NR==FNR{a[$3]=(a[$3]?a[$3]"\n"$00)}NR>FNR{print a[$1]}' file  



这个 太牛了 ,我是新手,受益匪浅啊

论坛徽章:
0
9 [报告]
发表于 2009-04-08 10:10 |只看该作者
原帖由 ywlscpl 于 2009-4-7 12:19 发表
awk -F ":" 'NR==FNR{a[$3]=(a[$3]?a[$3]"\n"$00)}NR>FNR{print a[$1]}' file  


这个厉害!今天才看懂,而且还有一定的通用性,佩服!谢谢!

论坛徽章:
0
8 [报告]
发表于 2009-04-07 12:19 |只看该作者
awk -F ":" 'NR==FNR{a[$3]=(a[$3]?a[$3]"\n"$00)}NR>FNR{print a[$1]}' file <(awk -F ":" '{b[$3]=1}END{for (j in b) print j}' file|sort -n)
uucp:5:5:UUCP administrator:/usr/lib/uucp:
uucp:5:3:UUCP administrator:/usr/lib/uucp:
uucp:6:2:UUCP administrator:/usr/lib/uucp:
uucp:6:1:UUCP administrator:/usr/lib/uucp:

[ 本帖最后由 ywlscpl 于 2009-4-7 12:20 编辑 ]

论坛徽章:
0
7 [报告]
发表于 2009-04-07 12:10 |只看该作者

回复 #3 blackold 的帖子

学习了。

论坛徽章:
0
6 [报告]
发表于 2009-04-07 11:57 |只看该作者
原帖由 blackold 于 2009-4-7 11:30 发表
sort 会进行重排。-s 禁止重排。


我这没有这个参数!还有招吗?

论坛徽章:
0
5 [报告]
发表于 2009-04-07 11:49 |只看该作者
学习了。。。
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP