文本内容处理命令和正则表达式

文本内容处理命令

grep

用来过滤文本内容,以匹配要查询的结果。

-m 数字 匹配几次后停止:

grep -m 1 /root/etc/passwd #查找包含root的行

-v 取反

-i 忽略字符的大小写,默认的,可以不加

-n 显示匹配的行号

-c 统计匹配的行数

-o 仅显示匹配到的字符串

-q 静默模式

-A 数字 after 包含匹配到的行,以及后几行。

-B 数字 包含匹配到的行,以及前几行

-C 数字 包含匹配到的行,以及前后各几行

-w 匹配整个单词

-E 使用扩展正则表达式 egrep=grep -E

-f 匹配两个文件中的相同内容,以第一个文件的内容为准

-r 递归目录,查找文件内容,软连接的内容不包含

-R 递归目录,查找文件内容,包含软连接的内容

复制代码
grep -m \# 匹配\#次后停止
grep -m 1 root /etc/passwd #多个匹配只取第一个

-A \# after, 后\#行
grep -A3 root /etc/passwd #匹配到的行后3行也显示出来
-B \# before, 前\#行
-C \# context, 前后各\#行

grep [] file 默认使用正则表达式来匹配模式
"^......"表示以......开头,"......$"表示以......结尾
"^$"表示空行
ifconfig ens33 |grep -Eo "[0-9]\+\.[0-9]\+\.[0-9]\+\.[0-9]\+"|head -1
ifconfig ens33 |grep -Eo "([0-9]{1,3}\.){3}[0-9]{1,3}"|head -1

sort

sort 对文本文件中的数据进行排序

sort -n 将字符串按数值排序

sort -M 将三字符的月份名按月份排序(常用于Linux日志文件每行起始的时间戳)

sort -b 排序时忽略起始的空白字符

sort -r 逆序排序(升序变降序,便于查看目录中哪些文件占用磁盘空间最多)

sort -R 随机排序

sort -f 选项忽略(fold)字符串中的字符大小写

sort -u 选项(独特,unique),合并重复项,即去重

sort -k 排序键从POS1位置开始,到POS2位置结束(如果指定了POS2的话)

sort -t 指定字段分隔符

例:sort -t ':' -k 3 -n /etc/passwd

uniq

uniq 单独使用是对连续重复的行去重

uniq -c 显示每行连续出现的次数

uniq -d 仅显示连续重复过的行

uniq -u 仅显示不曾连续重复的行

cat log|cut -d" " -f1|sort|uniq -c|sort -nr |head 查看访问日志,找出访问前10名的用户

tr

格式:tr [选项]... SET1 [SET2]

SET 是一组字符串,一般都可按照字面含义理解

tr -d 删除

tr -s 压缩

tr -c 用字符集2中的字符替换字符串1中字符集的补集,要求字符集为ASCII。

cut

cut -d (delimiter): 指明分隔符,默认tab

cut -f 想要获取的字段

#: 第#个字段,例如 3

#,#,#:离散的多个字段,例如 1,3,6

#-#:连续的多个字段, 例如 1-6

混合使用:1-3,7

cut -c 取每行第几个字符

cut -b 取每行第几个字符

cut --complement 排除指定的字段

cut --output-delimiter 替换分隔符

例:cut -d ":" -f 1-3 /etc/passwd # 1-3表示1到3

cut -d ":" -f 1,3 /etc/passwd # 1,3表示1和3

cut d ":" -f 1-3 --output-delimiter=" " /etc/passwd # 将":"分隔符替换为"空格"

split

split [-b ][-C ][-l ][要切割的文件][输出文件名前缀][-a ]

split -b<字节> 指定按多少字节进行拆分,也可以指定 k、M、G、T 等单位。

split -<行数>或-l<行数> 指定每多少行要拆分成一个文件。

输出文件名前缀:设置拆分后的文件的名称前缀,没有指定拆分后文件的命名方式的情况下,split 会默认采用 x 字符作为文件前缀,并在前缀后加上编号,默认从 aa 开始。

split -a<后缀长度>:默认的后缀长度是 2,也就是按 aa、ab、ac 这样的格式依次编号。

统计当前主机状态

复制代码
ss -antp | grep -v '^State' | cut -d ' ' -f 1 | sort | uniq -c

统计nginx的访问日志当中多次出现的ip地址

复制代码
cat /var/log/nginx/access.log | cut -d " " -f 1 | sort | uniq -c

正则表达式

通配符:用来匹配文件名或者目录名

*:任意一个或多个字符

?:任意的单个字符

匹配任意单个字符

a-z

A-Z

0-9

正则表达式

按照一定的格式和符号来匹配文件内容(命令输出的结果)

正则表达式的格式:

基本正则表达式 grep

扩展正则表达式 grep -E = egrep

使用正则表达式,匹配内容最好是用 引号 引起来。

元字符

复制代码
.:任意单个字符
\:表示转义符
[0-9]:匹配文件内容的任意单个数字
[a-z]:匹配文件内容的任意单个小写字母
[A-Z]:匹配文件内容的任意单个大写字母
():分组
[^]:取反
[:alnum:]:字母和数字,等价于**[0-9a-zA-Z]**
[:alpha:]:代表任何英文大小写字符,亦即 [A-Za-z]
[[:lower:]]:小写字母相当于 [a-z]
[[:upper:]]:大写字母相当于 [A-Z]
[[:blank:]]:空白字符(空格和制表符)
[:space:]:包括空格、制表符(水平和垂直)、换行符、回车符等各种类型的空白,比 [:blank:] 包含的范围广
[:cntrl:]:不可打印的控制字符(退格、删除、警铃...)
[:digit:]:十进制数字
[:xdigit:]:十六进制数字
[:graph:]:可打印的非空白字符
[:print:]:可打印字符
[:punct:]:标点符号
\w:匹配单词构成部分,等价于**[[:alnum:]]**
\W:匹配非单词构成部分,等价于**[^_[:alnum:]]**
\S:匹配任何非空白字符。等价于 [^ \f\n\r\t\v]
\s:匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [\f\n\r\t\v]

匹配次数

复制代码
*:任意字符,表示匹配前面的任意字符,0次,尽可能多的匹配
.*:匹配任意长度的字符,最少要有一次。也就是匹配所有
?:匹配前面的字符0次或者1次,可有可无
\+:匹配前面的字符,最少出现1次有且>=1
\{n\}:匹配前面的字符等于多少次
\{m,n\}:匹配前面的字符最少m次,最多n次
\{,n\}:匹配前面的最多n次,只要比n小,都算
\{n, \}:匹配前面的字符至少n次,只要比n大,都算
使用拓展正则表达式将"\"去掉即可

位置锚定

复制代码
^:以什么开始
$:以什么结尾
^$:空行(tab或\n)
^root$ :匹配整个单词,且这一行只有这个单词
词首锚定:\b
词尾锚定:\b

显示/etc/passwd中以sh结尾的行

复制代码
grep -E "sh$" /etc/passwd

查找/etc/inittab中含有"以s开头,并以d结尾的单词"模式的行

复制代码
grep -E "\bs[a-z]*d\b" /etc/inittab

查找ifconfig命令结果中的1-255之间的整数

复制代码
ifconfig ens33 | grep -Eo "\b[1-9]\b|\b[1-9][0-9]\b|\b1[0-9]{2}\b|\b2[0-4][0-9]\b|\b25[0-5]\b"

在/etc/passwd中取出默认shell为bash的行

复制代码
grep -E "bash$" /etc/passwd

高亮显示passwd文件中冒号,及其两侧的字符

复制代码
grep -E ".?:.?" /etc/passwd
相关推荐
Johny_Zhao1 小时前
Docker + CentOS 部署 Zookeeper 集群 + Kubernetes Operator 自动化运维方案
linux·网络安全·docker·信息安全·zookeeper·kubernetes·云计算·系统运维
小毛驴8501 小时前
Linux 后台启动java jar 程序 nohup java -jar
java·linux·jar
一心0922 小时前
ubuntu 20.04.6 sudo 源码包在线升级到1.9.17p1
运维·ubuntu·sudo·漏洞升级
好好学习啊天天向上2 小时前
世上最全:ubuntu 上及天河超算上源码编译llvm遇到的坑,cmake,ninja完整过程
linux·运维·ubuntu·自动性能优化
你想考研啊3 小时前
三、jenkins使用tomcat部署项目
运维·tomcat·jenkins
tan180°3 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
代码老y4 小时前
Docker:容器化技术的基石与实践指南
运维·docker·容器
典学长编程4 小时前
Linux操作系统从入门到精通!第二天(命令行)
linux·运维·chrome
wuk9984 小时前
基于MATLAB编制的锂离子电池伪二维模型
linux·windows·github
你想考研啊6 小时前
四、jenkins自动构建和设置邮箱
运维·jenkins