seq、tr、grep、cut、xargs、uniq、sort常用命令
1.seq命令
seq:产生序列
[root@localhost home]# seq 3
1
2
3
[root@localhost home]# seq 2 3
2
3
[root@localhost home]# seq 4 -1 0
4
3
2
1
0
for循环与seq结合 达到控制循环
for i in$(seq $num)
seq -w 宽度
[root@localhost home]# seq 1 10
1
2
3
4
5
6
7
8
9
10
[root@localhost home]# seq -w 1 10
01
02
03
04
05
06
07
08
09
10
seq -s 分隔符
[root@localhost home]# seq -s / 10
1/2/3/4/5/6/7/8/9/10
[root@localhost home]# seq -s + 10 | bc
55
2.tr命令
字符转换工具 tr set1 set2
[root@localhost home]# echo 12345 | tr 123 abc
abc45
[root@localhost home]# echo 1231111111111122|tr 123 abc 将123替换为abc
abcaaaaaaaaaaabb
[root@localhost home]# echo 1231111111111122333|tr 123 ab
abbaaaaaaaaaaabbbbb
对称的字符,一一对应;不对称的字符,最后一个字符对应所有的剩下的字符
tr不会直接修改原文件,只是处理好输出
tr -d 删除功能
[root@localhost home]# cat /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
[root@localhost home]# cat /etc/hosts|tr -d [0-9]
... localhost localhost.localdomain localhost localhost.localdomain
:: localhost localhost.localdomain localhost localhost.localdomain
tr -s 压缩字符串
[root@localhost home]# echo 111111111222233| tr -s 123 将所有的1压缩为一个1
123
3.grep命令
过滤信息
[root@localhost home]# df -Th | grep "tmpfs"
devtmpfs devtmpfs 883M 0 883M 0% /dev
tmpfs tmpfs 901M 0 901M 0% /dev/shm
tmpfs tmpfs 901M 8.7M 892M 1% /run
tmpfs tmpfs 901M 0 901M 0% /sys/fs/cgroup
tmpfs tmpfs 181M 0 181M 0% /run/user/0
[root@localhost home]# df -Th | grep "0$" $代表以什么结尾
tmpfs tmpfs 181M 0 181M 0% /run/user/0
[root@localhost home]# cat passwd | tr ":" "\n" | grep root
root
root
/root
/root
4.cut命令
提取范围
n 第n项
n,m 第n项和第m项
n-m 从n项到m项
n- 第n项到末尾
从文本文件或者文本流中提取文本列
-c 从指定提取范围中提取字符
[root@localhost home]# echo 123456abc |cut -c 5-9 截取5到第9个的字符
56abc
-d 指定分隔符。默认分隔符是tab
-f 从指定提取范围中提取字符(列)
[root@localhost home]# echo 1#2#3#4| cut -d "#" -f 3
3
[root@localhost home]# df -Th | tr -s " "| cut -d " " -f 1,5
文件系统 可用
devtmpfs 883M
tmpfs 901M
tmpfs 892M
tmpfs 901M
/dev/mapper/cl-root 15G
/dev/sda1 767M
tmpfs 181M
5.xargs命令:将前面命令的输出送给后面的命令作为参数使用
对比: |管道pipe:将前面命令输出送给后面的命令作为输入,不会给你送到参数的位置
[root@localhost home]# ls
nihao1 nihao2 nihao3 nihao4 nihao5 nihao6 nihao7 nihao8 nihao9 passwd
[root@localhost home]# ls -d nihao* | rm -rf
[root@localhost home]# ls
nihao1 nihao2 nihao3 nihao4 nihao5 nihao6 nihao7 nihao8 nihao9 passwd
[root@localhost home]# ls -d nihao* | xargs rm -rf
[root@localhost home]# ls
passwd
6.uniq命令:删除经过排序后的数据的重复记录
[root@localhost home]# df
文件系统 1K-块 已用 可用 已用% 挂载点
devtmpfs 903872 0 903872 0% /dev
tmpfs 921916 0 921916 0% /dev/shm
tmpfs 921916 8880 913036 1% /run
tmpfs 921916 0 921916 0% /sys/fs/cgroup
/dev/mapper/cl-root 17811456 2401432 15410024 14% /
/dev/sda1 999320 145372 785136 16% /boot
tmpfs 184380 0 184380 0% /run/user/0
[root@localhost home]# df | awk '{print $1}' | sort | uniq
文件系统
/dev/mapper/cl-root
/dev/sda1
devtmpfs
tmpfs
uniq -c 可以统计重复次数
[root@localhost home]# df | awk '{print $1}' | sort | uniq -c
1 文件系统
1 /dev/mapper/cl-root
1 /dev/sda1
1 devtmpfs
4 tmpfs
uniq -u 只显示不重复的
[root@localhost home]# df | awk '{print $1}' | sort | uniq -u
文件系统
/dev/mapper/cl-root
/dev/sda1
devtmpfs
uniq -d 只显示重复的
[root@localhost home]# df | awk '{print $1}' | sort | uniq -d
tmpfs
7.sort 命令
默认按每行的第一行里的i个字母的ASCII码值大小排序。升序排序
[root@localhost home]# cat passwd |sort | tail -5
systemd-coredump:x:999:997:systemd Core Dumper:/:/sbin/nologin
systemd-resolve:x:193:193:systemd Resolver:/:/sbin/nologin
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
unbound:x:997:995:Unbound DNS resolver:/etc/unbound:/sbin/nologin
yalin:x:1009:1009::/home/yalin:/bin/bash
-r 颠倒顺序 取反(降序)
[root@localhost home]# cat passwd |sort -r | tail -5
chrony:x:994:991::/var/lib/chrony:/sbin/nologin
califeng:x:1010:1010::/home/califeng:/bin/bash
cali123:x:1011:1011::/home/cali123:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin