shell小工具

目录

sort

sort 是一个以行为单位对文件内容进行排序的工具,也可以根据不同的数据类型来排序

格式:
sort [选项] 参数

参数:
-f:忽略大小写
-b:忽略每行前面的空格
-M:按照月份进行排序
-n:按照数字进行排序
-r:反向排序
-u:等同于 uniq,表示相同的数据仅显示一行
-t:指定分隔符,默认使用[Tab]键分隔
-o <输出文件>:将排序后的结果转存至指定文件
-k:指定排序区域

实例:
[root@localhost ~]# sort /etc/passwd '#将/etc/passwd 文件中的账号进行排序,根据行首字母顺序排序'
[root@localhost ~]# sort -t ':' -rk 3 /etc/passwd '#将/etc/passwd 文件中第三列进行反向排序,根据第三列第一个字符的顺序排序'
[root@localhost ~]# sort -t ':' -k 3 /etc/passwd -o user.txt '#将/etc/passwd 文件中第三列进行排序,并将输出内容保存至user.txt 文件中'

uniq

Uniq 工具在 Linux 系统中通常与 sort 命令结合使用,用于报告或者忽略文件中的重复行

格式:
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:取代所有不属于第一字符集的字符
-d:删除所有属于第一字符集的字符
-s:把连续重复的字符以单独一个字符表示
-t:先删除第一字符集较第二字符集多出的字符

实例:
[root@localhost opt]# echo "ABC" | tr 'A-Z' 'a-z' #将大写的字母换成小写的字母
[root@localhost opt]# echo "ABC" | tr -d 'B' #删除某个字符
[root@localhost opt]# echo "ABBBBBBBBC" | tr -s 'B' #压缩输入中的重复字符(将多个重复变成一个)

cut

cut:列截取工具

选项
-b按字节截取
-c按字符截取,常用于截取中文
-d指定以什么分隔符截取,默认制表符
-f通常和-d一起使用

实例
[root@localhost ~]# cat p.txt | cut -b 2 #截取文件内容每行第2个字符
o
i
a
d
p
y
h
a
a
p
[root@localhost ~]# cat p.txt | cut -d: -f1 #以:分隔,截取第一列
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
operator
[root@localhost ~]# cat p.txt | cut -d: -f1-3 #以:分隔,截取1-3列
root:x:0
bin:x:1
daemon:x:2
adm:x:3
lp:x:4
sync:x:5
shutdown:x:6
halt:x:7
mail:x:8
operator:x:11
[root@localhost ~]# cat p.txt | cut -d: -f1,3 #以:分隔,截取第1列和第3列
root:0
bin:1
daemon:2
adm:3
lp:4
sync:5
shutdown:6
halt:7
mail:8
operator:11

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值