免费注册 查看新帖 |

Chinaunix

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

一个文件排序问题。谢谢回答 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-03-27 12:41 |只看该作者 |倒序浏览
假如有下列文件:
aaa_950.txt
aaa_900.txt
aaa_1000.txt
aaa_2000.txt

怎样用比较简单的命令组合才能让输出为:
aaa_900.txt
aaa_950.txt
aaa_1000.txt
aaa_2000.txt

即:能够逐字比较排序输出。希望命令能比较通用的, 我只是举个例子表示我的问题。

十分感谢。

论坛徽章:
0
2 [报告]
发表于 2007-03-27 12:48 |只看该作者
awk -F"[_.]" '{printf("%08d %s\n",$2,$0);}' a.txt|sort -k1|awk '{print $2}'

论坛徽章:
0
3 [报告]
发表于 2007-03-27 12:50 |只看该作者
sort -t"_" -k2n a.txt

论坛徽章:
0
4 [报告]
发表于 2007-03-27 13:04 |只看该作者
sort -t"_" -k2n a.txt



我想假设的情况是: 假如我们不知道是那一列,

aaa_bbb_ccc_..._..._950_nnnn.txt
aaa_bbb_ccc_..._..._900_nnnn.txt
aaa_bbb_ccc_..._..._1000_nnnn.txt
aaa_bbb_ccc_..._..._1050_nnnn.txt



只知道某一列不一样, 我们就想要按这一列从大到小排序。


要求命令输出是:
aaa_bbb_ccc_..._..._900_nnnn.txt
aaa_bbb_ccc_..._..._950_nnnn.txt
aaa_bbb_ccc_..._..._1000_nnnn.txt
aaa_bbb_ccc_..._..._1050_nnnn.txt

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
5 [报告]
发表于 2007-03-27 13:42 |只看该作者
原帖由 wangcaipapa 于 2007-3-27 13:04 发表
sort -t"_" -k2n a.txt



我想假设的情况是: 假如我们不知道是那一列,

aaa_bbb_ccc_..._..._950_nnnn.txt
aaa_bbb_ccc_..._..._900_nnnn.txt
aaa_bbb_ccc_..._..._1000_nnnn.txt
aa ...


不一样的那一列肯定是数字吗?

论坛徽章:
0
6 [报告]
发表于 2007-03-27 13:59 |只看该作者
  1. ls |sed 's,[^0-9]*\([0-9]*\).*,\1 &,' |sort -n |cut -d' ' -f2
复制代码

论坛徽章:
0
7 [报告]
发表于 2007-03-27 14:25 |只看该作者
  1. awk '
  2. {
  3.         a[NR]=$0;

  4.         if(NR==1) {
  5.                 mstr=$0;
  6.         }
  7.         else if(index($0,mstr)==1) {
  8.                 continue;
  9.         }
  10.         else {
  11.                 for(i=1;i<length(mstr);i++) {
  12.                         if(substr(mstr,i,1)!=substr($0,i,1)) {
  13.                                 break;
  14.                         }
  15.                 }
  16.                 mstr=substr(mstr,1,i-1);
  17.         }
  18. }
  19. END {
  20.         pos=length(mstr);
  21.         for(i=1;i<=NR;i++) {
  22.                 match(substr(a[i],pos+1), "[0-9]+");
  23.                 num=substr(a[i],pos+RSTART,RLENGTH);
  24.                 printf("%s|%s\n",num,a[i]);
  25.         }
  26. }' a.txt|sort -k1n|cut -d"|" -f2
复制代码


整个复杂的,不知道楼主愿意是不是这样
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP