linux中srot和uniq命令
0x1 sort命令
命令说明:
sort命令将文本文件内容加以排序,sort可针对文本文件的内容,以行为单位来排序
参数:
-b 忽略每行前面开始出的空格字符。
-c 检查文件是否已经按照顺序排序。
-d 排序时,处理英文字母、数字及空格字符外,忽略其他的字符。
-f 排序时,将小写字母视为大写字母。
-i 排序时,除了040至176之间的ASCII字符外,忽略其他的字符。
-m 将几个排序好的文件进行合并。
-M 将前面3个字母依照月份的缩写进行排序。
-n 依照数值的大小排序。
-o<输出文件> 将排序后的结果存入指定的文件。
-r 以相反的顺序来排序。
-t<分隔字符> 指定排序时所用的栏位分隔字符。
+<起始栏位>-<结束栏位> 以指定的栏位来排序,范围由起始栏位到结束栏位的前一栏位。
–help 显示帮助。
–version 显示版本信息
举例:
1、sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出,在这一点上和cat命令稍有区别
2、sort的-u 选项它的作用很简单,就是在输出行中去除重复行,相比于uniq 的-u选项去重仅仅作用于相邻行,而sort -u去重的作用则是全局
3、sort的-n选项依照数值的大小排序
0x2 uniq 命令
命令说明:
Linux uniq 命令用于检查及删除文本文件中重复出现的行列,一般与 sort 命令结合使用。
uniq 可检查文本文件中重复出现的行列
参数:
-u或–unique 仅显示出一次的行列。
-c或–count 在每列旁边显示该行重复出现的次数。
-d或–repeated 仅显示重复出现的行列。
-f<栏位>或–skip-fields=<栏位> 忽略比较指定的栏位。
-s<字符位置>或–skip-chars=<字符位置> 忽略比较指定的字符。
-w<字符位置>或–check-chars=<字符位置> 指定要比较的字符。
–help 显示帮助。
–version 显示版本信息。
[输入文件] 指定已排序好的文本文件。如果不指定此项,则从标准读取数据;
[输出文件] 指定输出的文件。如果不指定此选项,则将内容显示到标准输出设备(显示终端)
举例:
1.使用 uniq 命令删除重复的行,可使用以下命令:
uniq -u kh.txt
2.检查文件并删除文件中重复出现的行,并在每列旁边显示该行重复出现的次数,可使用如下命令:
上一篇: 文本编辑器—sort与uniq工具
下一篇: Shell-diff用法