Linux 的 ‘sort’命令的14个有用的范例(一)

Linux 的 ‘sort’命令的14个有用的范例(一)

Sort是用于对单个或多个文本文件内容进行排序的Linux程序。Sort命令以空格作为字段分隔符,将一行分割为多个关键字对文件进行排序。需要注意的是除非你将输出重定向到文件中,否则Sort命令并不对文件内容进行实际的排序(即文件内容没有修改),只是将文件内容按有序输出。

本文的目标是通过14个实际的范例让你更深刻的理解如何在Linux中使用sort命令。

1、 首先我们将会创建一个用于执行‘sort’命令的文本文件(tecmint.txt)。工作路径是‘/home/$USER/Desktop/tecmint’。

下面命令中的‘-e’选项将启用‘\’转义,将‘\n’解析成换行


  1. $ echo -e "computer\nmouse\nLAPTOP\ndata\nRedHat\nlaptop\ndebian\nlaptop" > tecmint.txt

Split String by Lines in Linux

2、 在开始学习‘sort’命令前,我们先看看文件的内容及其显示方式。


  1. $ cat tecmint.txt

Check Content of File

3、 现在,使用如下命令对文件内容进行排序。


  1. $ sort tecmint.txt

Sort Content of File linux

注意:上面的命令并不对文件内容进行实际的排序,仅仅是将其内容按有序方式输出。

4、 对文件‘tecmint.txt’文件内容排序,并将排序后的内容输出到名为sorted.txt的文件中,然后使用cat命令查看验证sorted.txt文件的内容。


  1. $ sort tecmint.txt > sorted.txt
  2. $ cat sorted.txt

Sort File Content in Linux

5、 现在使用‘-r’参数对‘tecmint.txt’文件内容进行逆序排序,并将输出内容重定向到‘reversesorted.txt’文件中,并使用cat命令查看文件的内容。


  1. $ sort -r tecmint.txt > reversesorted.txt
  2. $ cat reversesorted.txt

Sort Content By Reverse

6、 创建一个新文件(lsl.txt),文件内容为在home目录下执行‘ls -l’命令的输出。


  1. $ ls -l /home/$USER > /home/$USER/Desktop/tecmint/lsl.txt
  2. $ cat lsl.txt

Populate Output of Home Directory

我们将会看到对其他字段进行排序的例子,而不是对默认的开始字符进行排序。

7、 基于第二列(符号连接的数量)对文件‘lsl.txt’进行排序。


  1. $ sort -nk2 lsl.txt

注意:上面例子中的‘-n’参数表示对数值内容进行排序。当想基于文件中的数值列对文件进行排序时,必须要使用‘-n’参数。

Sort Content by Column

8、 基于第9列(文件和目录的名称,非数值)对文件‘lsl.txt’进行排序。


  1. $ sort -k9 lsl.txt

Sort Content Based on Column

9、 sort命令并非仅能对文件进行排序,我们还可以通过管道将命令的输出内容重定向到sort命令中。


  1. $ ls -l /home/$USER | sort -nk5

Sort Content Using Pipe Option

10、 对文件tecmint.txt进行排序,并删除重复的行。然后检查重复的行是否已经删除了。


  1. $ cat tecmint.txt
  2. $ sort -u tecmint.txt

Sort and Remove Duplicates

目前我们发现的排序规则:

除非指定了‘-r’参数,否则排序的优先级按下面规则排序

  • 以数字开头的行优先级最高
  • 以小写字母开头的行优先级次之
  • 待排序内容按字典序进行排序
  • 默认情况下,‘sort’命令将带排序内容的每行关键字当作一个字符串进行字典序排序(数字优先级最高,参看规则 1)

11、 在当前位置创建第三个文件‘lsla.txt’,其内容用‘ls -lA’命令的输出内容填充。


  1. $ ls -lA /home/$USER > /home/$USER/Desktop/tecmint/lsla.txt
  2. $ cat lsla.txt

Populate Output With Hidden Files

了解ls命令的读者都知道‘ls -lA’ 等于 ‘ls -l’ + 隐藏文件,所以这两个文件的大部分内容都是相同的。

12、 对上面两个文件内容进行排序输出。


  1. $ sort lsl.txt lsla.txt

Sort Contents of Two Files

注意文件和目录的重复

13、 现在我们看看怎样对两个文件进行排序、合并,并且删除重复行。


  1. $ sort -u lsl.txt lsla.txt

Sort, Merge and Remove Duplicates from File

此时,我们注意到重复的行已经被删除了,我们可以将输出内容重定向到文件中。

14、 我们同样可以基于多列对文件内容进行排序。基于第2,5(数值)和9(非数值)列对‘ls -l’命令的输出进行排序。


  1. $ ls -l /home/$USER | sort -t "," -nk2,5 -k9

Sort Content By Field Column

先到此为止了,在接下来的文章中我们将会学习到‘sort’命令更多的详细例子。届时敬请关注我们。保持分享精神。若喜欢本文,敬请将本文分享给你的朋友。

原文发布时间:2015-05-02

本文来自云栖合作伙伴“linux中国”

时间: 2025-01-24 14:48:26

Linux 的 ‘sort’命令的14个有用的范例(一)的相关文章

Linux 的 'sort'命令的七个有趣实例(二)

Linux 的 'sort'命令的七个有趣实例(二) 在上一篇文章里,我们已经探讨了关于sort命令的多个例子,如果你错过了这篇文章,可以点击下面的链接进行阅读.今天的这篇文章作为上一篇文章的继续,将讨论关于sort命令的剩余用法,与上一篇一起作为Linux 'sort'命令的完整指南. Linux 的 'sort'命令的14个有用的范例(一) 在我们继续深入之前,先创建一个文本文档'month.txt',并且将上一次给出的数据填进去. $ echo -e "mar\ndec\noct\nsep

14个实战案例带你了解Linux的‘sort’命令

sort是什么 Sort是用于对单个或多个文本文件内容进行排序的Linux程序. Sort命令以空格作为字段分隔符,将一行分割为多个关键字对文件进行排序. 请注意,除非你将输出重定向到文件中,否则Sort命令并不对文件内容进行实际的排序(即文件内容没有修改),只是将文件内容按有序输出. 本文的目标是通过14个实际的范例让你更深刻的理解如何在Linux中使用sort命令.  实战演示 1.目标文件创建 首先创建一个用于执行'sort'命令的文本文件(tecmint.txt). 工作路径是'/hom

linux中sort命令的用法

Sort命令的功能是对文件中的各行进行排序.Sort命令有许多非常实用的选项,这些选项最初是用来对数据库格式的文件内容进行各种排序操作的.实际上,Sort命令可以被认为是一个非常强大的数据管理工具,用来管理内容类似数据库记录的文件. Sort命令将逐行对文件中的内容进行排序,如果两行的首字符相同,该命令将继续比较这两行的下一字符,如果还相同,将继续进行比较. 语法: Sort [选项] 文件 说明:Sort命令对指定文件中所有的行进行排序,并将结果显示在标准输出上.如不指定输入文件或使用"- &

Linux关于sort命令的高级用法

如果单纯地使用sort按行进行排序比较简单, 但是使用sort按多个列值排列,同时使用tab作为分隔符,而且对于某些列需要进行逆序排列,这样sort命令写起来就比较麻烦了 比如下面的文件内容,使用[TAB]进行分割: Group-ID   Category-ID   Text        Frequency ---------------------------------------------- 200        1000          oranges     10 200    

奇怪的组合-linux sort命令:诡异的组合,大佬给个解释呗,谢谢

问题描述 linux sort命令:诡异的组合,大佬给个解释呗,谢谢 sort onebak.tmp | uniq -c | sort -k1,1n -k2,2n |tail -30 >oneresult 对于sort -k1,1n -k2,2n我的理解是第一域相同,比较第二域,比较方式是n数值. 如果我的理解没错的话,sort -n -k1 -k2 这样不是更加简洁吗? 解决方案 http://www.cnblogs.com/51linux/archive/2012/05/23/2515299

linux 管理小命令5—— 排序与统计命令sort wc uniq

1• sort sort 是很有趣的指令,他可以帮我们进行排序,而且可以依据不同的数据型态来排序喔! 例如数字与文字的排序就不一样.此外,排序的字符与语系的编码有关,因此, 如果您需要排序时,建议使用 LC_ALL=C 来让语系统一,数据排序比较好一些. [root@linux ~]# sort [-fbMnrtuk] [file or stdin] 参数: -f :忽略大小写的差异,例如 A 与 a 视为编码相同: -b :忽略最前面的空格符部分: -M :以月份的名字来排序,例如 JAN,

详解linux sort命令工作原理及使用教程

sort是在Linux里非常常用的一个命令,管排序的,集中精力,五分钟搞定sort,现在开始! 1 sort的工作原理 sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出. [rocrocket@rocrocket programming]$ cat seq.txt banana apple pear orange [rocrocket@rocrocket programming]$ sort seq.txt apple ba

linux sort命令参数及用法详解

  功能说明:将文本文件内容加以排序. 语 法:sort [-bcdfimMnr][-o<输出文件>][-t<分隔字符>][+<起始栏位>-<结束栏位>][--help][--verison][文件] 补充说明:sort可针对文本文件的内容,以行为单位来排序. 参 数: -b 忽略每行前面开始出的空格字符. -c 检查文件是否已经按照顺序排序. -d 排序时,处理英文字母.数字及空格字符外,忽略其他的字符. -f 排序时,将小写字母视为大写字母. -i 排序

linux下uniq和sort命令用法详解

  1.uniq命令 使用说明:这个命令读取输入文件,并比较相邻的行.在正常情况下,第二个及以后更多个重复行将被删去,行比较是根据所用字符集的排序序列进行的.该命令加工后的结果写到输出文件中.输入文件和输出文件必须不同.如果输入文件用"- "表示,则从标准输入读取. 该命令各选项含义如下: -c 显示输出中,在每行行首加上本行在文件中出现的次数.它可取代- u和- d选项. -d 只显示重复行. -u 只显示文件中不重复的各行. -n 前n个字段与每个字段前的空白一起被忽略.一个字段是