sort工具
- sort命令
以行为单位对文件内容进行排序,也可以根据不同的数据类型来排序
语法格式
sort [选项] 参数
cat file | sort 选项
常用选项
-f:忽略大小写,默认会将大写字母排在前面
-b:忽略前导区域的区域
-n:按照数字进行排序
-r:反向排序
-u:等同于uniq,表示相同的数据仅显示一行
-t:指定字段分隔符,默认使用[Tab]键分隔
-k:指定排序字段
-o<输出文件>:将排序后的结果转存至指定文件
举例说明
# sort -n -t: -k3 1.txt //按照用户的uid进行升序排列
# sort -nr -t: -k3 1.txt //按照用户的uid进行降序排列
# sort -n 2.txt //按照数字排序
# sort -nu 2.txt //按照数字排序并且去重
# sort -nr 2.txt
# sort -nru 2.txt
# sort -nru 2.txt
# sort -n 2.txt -o 3.txt //按照数字排序并将结果重定向到文件
# sort -R 2.txt
# sort -u 2.txt
uniq命令
- uniq命令
用于报告或者忽略文件中连续的重复行,常与sort命令结合使用
语法格式
uniq [选项] 参数
cat file | uniq 选项
常用选项
-c 进行计数
-d 仅显示重复行
-u 仅显示出现一次的行
实例
[root@localhost ~]# uniq testfile //删除 testfile 文件中的重复行
[root@localhost ~]# uniq -c testfile //删除 testfile 文件中的重复行,并在行首显示该行重复出现的次数
[root@localhost ~]# uniq -d testfile //查找 testfile 文件中的重复行
tr工具
- tr命令
常用来对来自标准输入的字符进行替换、压缩和删除
语法格式
tr [选项] [参数]
注:这里的参数不能为文件!!!
常用选项
-c:保留字符集1的字符,其他的字符(包括换行符\n)用字符集2替换
-d:删除所有属于字符集1的字符
-s:将重复出现的字符串压缩为一个字符串;用字符集2替换字符集1
-t:字符集2替换字符集1,不加选项同结果。
实例
# tr -d '[:/]' < 3.txt 删除文件中的:和/
# cat 3.txt |tr -d '[:/]' 删除文件中的:和/
# tr '[0-9]' '@' < 3.txt 将文件中的数字替换为@符号
# tr '[a-z]' '[A-Z]' < 3.txt 将文件中的小写字母替换成大写字母
# tr -s '[a-z]' < 3.txt 匹配小写字母并将重复的压缩为一个
# tr -s '[a-z0-9]' < 3.txt 匹配小写字母和数字并将重复的压缩为一个
# tr -d '[:digit:]' < 3.txt 删除文件中的数字
# tr -d '[:blank:]' < 3.txt 删除水平空白
# tr -d '[:space:]' < 3.txt 删除所有水平和垂直空白
Here Document 免交互
概述
- 使用I/O重定向的方式将命令列表提供给交互式程序
- 标准输入的一种替代品
语法格式
命令 <<标记
...
内容 标记之间是传入内容
...
标记
注意事项
标记可以使用任意合法字符(通常为EOF)
结尾的标记一定要顶格写,前面不能有任何字符
结尾的标记后面也不能有任何字符(包括空格)
开头标记前后的空格会被省略掉
实例
- 免交互方式
1.免交互方式实现对行数的统计,将要统计的内容置于标记"EOF"之间,直接将内容传给 wc -l 来统计
wc -l <<EOF
>Line1
>Line2
>EОF
2.通过read命令接收输入并打印,输入值是两个EOF标记之间的部分,作为变量i的值
read只能输出一行内容
read i <<EOF
>Hi
>EOF
echo $i