免费注册 查看新帖 |

Chinaunix

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

请教一个排序问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-03-19 20:32 |只看该作者 |倒序浏览
有下面格式的文件:

2009/01/01
Q: 200
2009/01/02
Q: 300
2009/01/03
Q: 100
2009/01/04
Q: 150

想根据日期下面的数字排序,得到:
2009/01/02
Q: 300
2009/01/01
Q: 200
2009/01/04
Q: 150
2009/01/03
Q: 100

请问怎么用脚本实现?多谢!

论坛徽章:
0
2 [报告]
发表于 2009-03-19 20:40 |只看该作者
写得好差。。
[test@ ~ ]$ sed 'N;s/\n/#/' 1 |sort -k2 -nr|sed 's/#/\n/'
2009/01/02
Q: 300
2009/01/01
Q: 200
2009/01/04
Q: 150
2009/01/03
Q: 100

论坛徽章:
0
3 [报告]
发表于 2009-03-19 20:54 |只看该作者
来个awk的
[root@Mylinux tmp]# awk 'NR%2==1{printf $0","}NR%2==0' file |sort -k2rn|awk -F "," '{print $1"\n"$2}'
2009/01/02
Q: 300
2009/01/01
Q: 200
2009/01/04
Q: 150
2009/01/03
Q: 100

论坛徽章:
0
4 [报告]
发表于 2009-03-19 21:04 |只看该作者
我也写来一个

  1. paste - - < file | sort -k3nr | awk '{print $1"\n"$2,$3}'
复制代码

论坛徽章:
0
5 [报告]
发表于 2009-03-19 21:16 |只看该作者

回复 #4 yuchen12 的帖子

paste - - < file

赞一个

论坛徽章:
0
6 [报告]
发表于 2009-03-19 22:31 |只看该作者
非常感谢!
不过我试了:sed 'N;s/\n/#/' 1 |sort -k2 -nr|sed 's/#/\n/'

开始\n能被替换成#,但是后来#被替换成n了,不能被替换回成\n,应该怎么写呢?

论坛徽章:
1
寅虎
日期:2014-11-30 21:25:54
7 [报告]
发表于 2009-03-19 22:42 |只看该作者
原帖由 yuchen12 于 2009-3-19 21:04 发表
我也写来一个

paste - - < file | sort -k3nr | awk '{print $1"\n"$2,$3}'


paste - - < file  
是什么意思  谁给解释一下啊

论坛徽章:
0
8 [报告]
发表于 2009-03-19 23:26 |只看该作者
原帖由 yythinking 于 2009-3-19 22:31 发表
非常感谢!
不过我试了:sed 'N;s/\n/#/' 1 |sort -k2 -nr|sed 's/#/\n/'

开始\n能被替换成#,但是后来#被替换成n了,不能被替换回成\n,应该怎么写呢?



tr "#" "\n"

论坛徽章:
1
寅虎
日期:2014-11-30 21:25:54
9 [报告]
发表于 2009-03-21 00:25 |只看该作者

回复 #7 vbs100 的帖子

额~~ 想明白了
paste - - < file  的意思就是把file的2倍列宽合成一个新文件 相当于 paste -sd"\t\n" file
paste - - - < file 就是3倍了 ...  相当于 paste -sd"\t\t\n" file
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP