免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4371 | 回复: 11

[文本处理] 关于sort的问题 [复制链接]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
发表于 2014-01-23 16:55 |显示全部楼层
文本如下 bbs-list3
  1. aardvark 555-5553 1200/300      B
  2. alponet 555-3412 2400/1200/300 A
  3. barfly   555-7685 1200/300      A
  4. bites    555-1675 2400/1200/300 A
  5. camelot  555-0542 300           C
  6. core     555-2912 1200/300      C
  7. fooey    555-1234 2400/1200/300 B
  8. foot     555-6699 1200/300      B
  9. macfoo   555-6480 1200/300      A
  10. sdace    555-3430 2400/1200/300 A
  11. sabafoo  555-2127 1200/300      C
复制代码
我想先对第4列排序,然后在此基础上对第2列排序

1,用的命令 sort -k 4 -k 2.5,2.8n bbs-list3 无效
2,用的命令 sort -k 4 -k 2 bbs-list3 几乎快达到要求了 只是最后三行不符合要求
  1. bites    555-1675 2400/1200/300 A
  2. alponet 555-3412 2400/1200/300 A
  3. sdace    555-3430 2400/1200/300 A
  4. macfoo   555-6480 1200/300      A
  5. barfly   555-7685 1200/300      A
  6. fooey    555-1234 2400/1200/300 B
  7. aardvark 555-5553 1200/300      B
  8. foot     555-6699 1200/300      B
  9. sabafoo  555-2127 1200/300      C
  10. core     555-2912 1200/300      C
  11. camelot  555-0542 300           C
复制代码
清帮忙解释一下

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2014-01-23 17:08 |显示全部楼层
回复 1# sohusina


   按照你的命令,应该是
camelot  555-0542 300           C

排在最前吧?

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
发表于 2014-01-23 17:13 |显示全部楼层
本帖最后由 jason680 于 2014-01-23 17:17 编辑

回复 1# sohusina

$ sort -b -k4 -k2 bbs-list3
  1. bites    555-1675 2400/1200/300 A
  2. alponet 555-3412 2400/1200/300 A
  3. sdace    555-3430 2400/1200/300 A
  4. macfoo   555-6480 1200/300      A
  5. barfly   555-7685 1200/300      A
  6. fooey    555-1234 2400/1200/300 B
  7. aardvark 555-5553 1200/300      B
  8. foot     555-6699 1200/300      B
  9. camelot  555-0542 300           C
  10. sabafoo  555-2127 1200/300      C
  11. core     555-2912 1200/300      C
复制代码

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
发表于 2014-01-23 17:13 |显示全部楼层
回复 2# blackold
不是啊,就是因为这样我才觉得奇怪。

   

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2014-01-23 17:32 |显示全部楼层
回复 4# sohusina


    try:
  1. alias sort
复制代码

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
发表于 2014-01-23 17:53 |显示全部楼层
回复 3# jason680

-b参数的作用是忽略多余的空白符吗?
   

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
发表于 2014-01-23 18:01 |显示全部楼层
本帖最后由 jason680 于 2014-01-23 18:12 编辑

回复 6# yestreenstars

you got it
man sort
      ...
       -b, --ignore-leading-blanks
              ignore leading blanks


$ cat bb
x1  2
x2 2
y2 1
y1  1

$ sort -k2 -k1 bb
y2 1
y1   1
x2 2
x1  2

$ sort -b -k2 -k1 bb
y1  1
y2 1
x1  2
x2 2

   

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
发表于 2014-01-23 18:51 |显示全部楼层
回复 7# jason680

I got it. Thank you!
   

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2014-01-23 18:51 |显示全部楼层
本帖最后由 blackold 于 2014-01-23 18:52 编辑

回复 7# jason680


    啥环境?

我的环境下,用同样的数据:
  1. $ sort -s -k2,2 -k1,1 urfile
  2. y1  1
  3. x1  2
  4. y2 1
  5. x2 2
复制代码
  1. $ sort -k2 -k1 urfile
  2. y1  1
  3. x1  2
  4. y2 1
  5. x2 2
复制代码

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
发表于 2014-01-23 19:10 |显示全部楼层
本帖最后由 jason680 于 2014-01-23 19:28 编辑

回复 9# blackold

Ubuntu 12.04 and RHEL 4.4 have the same result

Ubuntu 12.04.3 LTS
$ sort --version
sort (GNU coreutils) 8.13
...

and

# cat /etc/redhat-release
Red Hat Enterprise Linux AS release 4 (Nahant Update 4)

# sort --version
sort (coreutils) 5.2.1
...

------------------------------------------------

# env | grep LANG
LANG=en_US.UTF-8

# LANG=C sort -k2 -k1 bb
y1  1
x1  2
y2 1
x2 2

# LANG=en_US.UTF-8 sort -k2 -k1 bb
y2 1
y1  1
x2 2
x1  2

# LANG=en_US.UTF-8 sort -b -k2 -k1 bb
y1  1
y2 1
x1  2
x2 2

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP