对文本的内容进行过滤,针对行处理
grep [选项]…查找条件 目标文件
-m+数字——————匹配几次后停止
eg:grep -m 1 root /etc/passwd————————————多个匹配只取
-v ————————取反
eg:grep -v root /etc/passwd————————————————除了root其余展示出来
-i —————————忽略字符大小写
eg:grep -i Root /etc/passwd————————————————不考虑大小写展示出来
-n——————————显示匹配行号
eg:grep -n root /etc/passwd
-c—————————只显示匹配行号
eg:grep -c root /etc/passwd
-o——————————仅显示匹配到的字符串
eg:grep -o root /etc/passwd
-A——————————匹配自身当前行的后三行,包含自身展示出来
eg:grep -A 3 zjf /etc/passwd
-B————————————自身前几行包含自身展示
eg:grep -B 3 zjf /etc/passwd
-C————————————本身的前三行和后三行以及本身展示出
eg:grep -C 3 zjf /etc/passwd
-e——————————————逻辑或,可以跟多个条件,若有显示,没有不显示
eg:grep -e root -e bash /etc/passwd
-w————————————匹配整个单词
eg:grep -w root /etc/passwd
-E——————————表示使用扩展正则相当于egrep
-f——————————根据模式文件处理两个文件的相同内容,第一个文件作为匹配条件
eg:grep -f 123.txt 456.txt
-r——————————递归目录文件当中的文件内容所包含的想要的文件内容
不对软链接处理
eg:grep -r a /opt/
-R——————————可以处理软链接中的文件内容
eg:grep -R a /opt/
示例:
cat 123.txt | grep -v "^$" > test.txt————过滤掉123.txt里的空行将内容传送给test.txt
grep “^所要让开头的字符” 文件名
示例:
grep "^4" 123.txt
grep "^a" 123.txt
grep “^所要让开头的字符” 文件名
示例:
grep "h$" 123.txt
格式:
^匹配的字符$
示例:
grep -n "^root$" dh.txt
以行为单位对文件内容进行排序,也可以根据不同的数据类型来排序
语法格式:
sort 选项 参数
-f————————————————忽略大小写,默认会大写字母排在前面
eg:sort -f test.txt
-b——————————————只排序不会忽略空格,忽略每行前面的空格
eg:sort -b test.txt
-n:按照数字进行排序
eg:sort -n test.txt
-r:针对字母的反向排序
eg:sort -r test.txt
-u:等同uniq,表示相同的数据仅显示一行,去重
eg:sort -u test.txt
-o <输出文件>:将排序后的结果转存至指定文件
eg:cat /opt/test.txt | sort -o zjf.txt
按原来的行一模一样的传到新的文件
uniq命令用于报告或者忽略文件中连续的重复行,常与sort命令结合使用。
uniq [选项] 参数
cat 文件| uniq 选项
-c——————————————统计连续重复的行的次数,并且合并重复的行
eg:uniq -c test1.txt
去重排序:
cat test1.txt | uniq -c test1.txt | sort -n
-u——————————————显示仅出现一次的行(包括不连续的重复行)
eg:uniq -u test1.txt
-d 仅显示重复出现的行(必须是连续的重复行)
eg:uniq -d test1.txt
常用于对来自标准输入的字符进行替换、压缩和删除
参数:
字符集1:
指定要转换或删除的原字符集。当执行转换操作时,
必须使用参数”字符集2“指定转换操作时,必须使用参数”字符集2“指定转换的目标字符集。
但执行删除操作时,不需要参数”字符集2“
字符集2:
指定要转换成的目标字符集
tr 选项 参数
-c:保留字符集1的字符,其他的字符(包括换行符\n)用字符集2替换
eg:echo abc | tr -c ‘ab’ ‘a’
-d:删除所有属于字符集1的字符
eg:echo abc | tr -d ‘ab’————————删除ab,打印c
-s:将重复出现的字符串压缩为一个字符串,用字符集2 替换 字符集1
eg:cat xx.txt | tr -s “w” “b”
-t:字符集2 替换 字符集1,不加也行
eg:echo 192.168.198.11 | tr “.” “:”
echo 192.168.198.11 | tr -d “.”
将 echo $PATH中的":"替换为换行
cut截取方法
对字段进行截取和剪裁
格式一:cut [选项] 参数
格式二:cat 文件名 | cut [选项]
-d 指定分隔符(默认分隔符为Tab)
-f 按字段进行截取。指定第n个字段;
-b 以字节为单位进行截取
-c 以字符为单位进行截取
–complement 排除所指定的字段
–output-delimiter 更改输出内容的分隔符
(1)cut -d ":" -f 1-3 /etc/passwd————————以":"作为分隔符,指定第一个到第三个字段进行输出
cat /etc/passwd | cut -d ":" -f 1-3
head -n 2 /etc/passwd | cut -d ":" --complement -f 2————————指定以":"作为分隔符,但是删除了第二个字段进行输出
head -n 2 /etc/passwd | cut -d ":" --complement -f 1-5 --output-delimiter="@"——————————将分隔符转换为@,进行输出
split命令用于在Linux下将大文件拆分为若干小文件。
split 选项 参数 原始文件 拆分后文件名前缀
-l 指定行数对文件拆分
-b 指定文件的大小拆分
split -l 20 test6.txt sc
split -b 2m test6.txt dx
按照字段来进行文件的合并
paste [选项] 文件1 文件2
-d 用于指定文件的分隔符(默认情况下为制表符"\n")
-s 将列和行的内容进行互相交换
paste和cat合并有什么区别
cat是上下合并
ss -nta | grep -v ‘^State’ |cut -d " " -f 1| sort | uniq -c
3 ESTAB #表示建立的 TCP 连接处于活动状态
17 LISTEN
ss -nt | tr -s " "|cut -d " " -f 5 | sort -n | uniq -c
1 Local
2 192.168.233.21:22