Shell中的sort排序命令的使用

本文详细介绍了Linux下的sort命令,包括其基本语法、常用参数及其应用场景。通过具体的实例演示了如何进行文本排序、逆序排序、数字排序及指定字段排序等操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

sort简介
   sort命令可以依据不同的数据类型进行排序,其语法及常用参数格式:
  sort [-bcfMnrtk][源文件][-o 输出文件] 
   补充说明:sort可针对文本文件的内容,以行为单位来排序。

参数:
  -b   忽略每行前面开始出的空格字符。
  -c   检查文件是否已经按照顺序排序。
  -f   排序时,忽略大小写字母。
  -M   将前面3个字母依照月份的缩写进行排序。
  -n   依照数值的大小排序。
  -o<输出文件>   将排序后的结果存入指定的文件。
  -r   以相反的顺序来排序。
  -t<分隔字符>   指定排序时所用的栏位分隔字符。
  -k  选择以哪个区间进行排序。


使用举例
   (1)sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出。
    #cat seq.txt
    banana
    apple
    pear
    orange
    #sort seq.txt
    apple
    banana
    orange
    pear
    用户可以保存排序后的文件内容,或把排序后的文件内容输出至打印机。下例中用户把排序后的文件内容保存到名为result.txt的文件中。
    #sort seq.txt > result.txt
   (2)sort默认的排序方式是升序,如果想改成降序,就加个-r就搞定了。
    #sort -r seq.txt
    pear
    orange
    banana
    apple
   (3)由于sort默认是把结果输出到标准输出,所以需要用重定向才能将结果写入文件,形如sort filename > newfile。但是,如果你想把排序结果输出到原文件中,用重定向可就不行了。
    #sort -r seq.txt > seq.txt
    #cat seq.txt
    #
    看,竟然将seq.txt文件清空了。就在这个时候,-o选项出现了,它成功的解决了这个问题,它能将结果写入原文件。这或许也是-o比重定向的唯一优势所在。
    # sort -r seq.txt -o seq.txt
   (4)你有没有遇到过10比2小的情况,出现这种情况是由于排序程序将这些数字按字符来排序了,排序程序会先比较1和2,显然1小,所以就将10放在2前面喽。这也是sort的一贯作风。如果想改变这种现状,就要使用-n选项,来告诉sort,“要以数值来排序”!
# cat /etc/passwd | awk 'BEGIN{FS=":"}{print $3"\t"$1}' | sort
0 root
10 uucp
11 operator
12 games
13 gopher
14 ftp
16 oprofile
173 abrt
1 bin
29 rpcuser
2 daemon
32 rpc
38 ntp
3 adm
499 saslauth
4 lp
500 tang
501 hadoop
5 sync
65534 nfsnobody
68 haldaemon
69 vcsa
6 shutdown
72 tcpdump
74 sshd
7 halt
81 dbus
89 postfix
8 mail
99 nobody
# cat /etc/passwd | awk 'BEGIN{FS=":"}{print $3"\t"$1}' | sort -n
0 root
1 bin
2 daemon
3 adm
4 lp
5 sync
6 shutdown
7 halt
8 mail
10 uucp
11 operator
12 games
13 gopher
14 ftp
16 oprofile
29 rpcuser
32 rpc
38 ntp
68 haldaemon
69 vcsa
72 tcpdump
74 sshd
81 dbus
89 postfix
99 nobody
173 abrt
499 saslauth
500 tang
501 hadoop
65534 nfsnobody
  (5)sort的-t选项和-k选项可以实现按照指定的列排序
   如果有一个文件的内容是这样:
   # cat facebook.txt
    banana:30:5.5
    apple:10:2.5
    pear:90:2.3
    orange:20:3.4
   这个文件有三列,列与列之间用冒号隔开了,第一列表示水果类型,第二列表示水果数量,第三列表示水果价格。那么我想以水果数量来排序,也就是以第二列来排序,如何利用sort实现?幸好,sort提供了-t选项,后面可以设定间隔符。指定了间隔符之后,就可以用-k来指定列数了。
  # sort -n -t‘:’-k 2  facebook.txt
   apple:10:2.5
   orange:20:3.4
   banana:30:5.5
   pear:90:2.3
### Shell 脚本中使用 `sort` 命令进行排序Shell 脚本中,`sort` 是一个强大的命令行工具,用于对文件内容进行排序。默认情况下,`sort` 按照字符顺序对每行进行排序,但可以通过多种选项实现更复杂的排序需求。 #### 基本排序 默认情况下,`sort` 会根据每行的字符顺序进行升序排序。例如: ```bash sort filename.txt ``` 此命令将按字母顺序对 `filename.txt` 中的内容进行排序。 #### 按数字排序 若数据中包含数值字段,使用 `-n` 选项可确保 `sort` 按数值大小进行排序,而不是按字符顺序排序。例如: ```bash sort -n numbers.txt ``` 此命令将按照数值大小对 `numbers.txt` 文件中的内容进行排序[^2]。 #### 降序排序 使用 `-r` 选项可以实现降序排序,即将默认的升序排序反转。例如: ```bash sort -r filename.txt ``` 该命令将按字符顺序的逆序对文件内容进行排序。 若需结合数值排序和降序排序,可使用以下命令: ```bash sort -nr numbers.txt ``` 此命令将先按数值大小排序,然后反转结果,最终输出降序排列的数值列表[^3]。 #### 按指定列排序 在处理结构化数据(如 CSV 或 TSV 文件)时,可以使用 `-t` 指定字段分隔符,并通过 `-k` 指定排序的列。例如,若有一个以冒号 `:` 分隔的文件 `data.txt`,可按第二列进行排序: ```bash sort -t : -k 2 data.txt ``` 若需按数值排序并降序排列,可添加 `-n` 和 `-r` 选项: ```bash sort -t : -nrk 2 data.txt ``` 此命令将按第二列的数值大小进行降序排序[^3]。 #### 忽略前导空格 使用 `-b` 选项可以忽略每行开头的空格字符,从而避免这些空格影响排序结果。例如: ```bash sort -b filename.txt ``` 此命令将忽略每行开头的空格,并基于后续字符进行排序[^1]。 #### 忽略大小写排序 若需在排序时忽略字母大小写,可使用 `-f` 选项。例如: ```bash sort -f filename.txt ``` 该命令将不区分大小写地对文件内容进行排序[^1]。 #### 去重排序 使用 `-u` 选项可在排序后去除重复行。例如: ```bash sort -u filename.txt ``` 此命令将对文件内容进行排序,并仅保留唯一行。 #### 综合示例 假设有一个包含用户名和成绩的文件 `scores.txt`,内容如下: ``` Alice:85 Bob:92 Charlie:78 David:92 Eve:85 ``` 若需按成绩降序排序,并在成绩相同时按姓名升序排序,可使用以下命令: ```bash sort -t : -k2nr -k1 scores.txt ``` 此命令首先按第二列(成绩)进行数值降序排序,若成绩相同,则按第一列(姓名)进行升序排序[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值