龙空技术网

2022全新正则表达式手册来了,程序员&运维人员必备宝典

老男孩IT教育 1265

前言:

目前小伙伴们对“正则表达式适用范围”可能比较看重,各位老铁们都想要分析一些“正则表达式适用范围”的相关内容。那么小编也在网摘上汇集了一些对于“正则表达式适用范围””的相关知识,希望各位老铁们能喜欢,各位老铁们一起来了解一下吧!

Linux系统中经常会利用一些特殊的符号字符来表示一些特定含义的内容,便于数据检索和数据匹配。

系统通配符号介绍1、系统通配符号简介

通配符号简单来说,就是键盘上的一些特殊符号,可以实现某些特殊的功能。

例如:用来模糊搜索系统中的文件,使用通配符号 * 和 ?字符来代替一个或多个真正的实际字符,从而提高检索效率

利用通配符可以在Linux命令行或bash脚本中轻松匹配或查找所需的文件,以提高工作效率。

通配符也是bash的内置功能,几乎适用于所有的Linux环境,常用的通配符号如下:

序号

符号

解释说明

01

*

匹配任意(0个或多个)字符或字符串,包括空字符串

02

匹配任意1个字符,有且只有一个字符

03

[abcd]

匹配abcd中任何一个字符,abcd也可是其他任意不连续字符

04

[a-z]

匹配a到z之间的任意一个字符,字符前后要连续,也可以用连续数字,即[1-9]

05

[!abcd]

表示不匹配括号里面的任何一个字符,也可写为[!a-d],这里的!号可以用^替代,即adbcd

06

{}

表示用于生成字符序列信息以及组合序列,结合$符号使用可以用于识别变量信息

2、系统通配符号详述01. *号的作用详述与实践

在Linux命令行通配符中,*号的意思是匹配所有(0到多个)字符;

在查找某一类文件时特别方便,在命令行中是十分常用的符号。

实践操作:

环境准备:

tiki wiki[xiaoQ@xiaoq ~]$ mkdir test[xiaoQ@xiaoq ~]$ cd test[xiaoQ@xiaoq test]$ touch xiaoQ.txt xiaoT.txt test.txt[xiaoQ@xiaoq test]$ touch xiaoC.sh[xiaoQ@xiaoq test]$ lstest.txt  xiaoC.sh  xiaoQ.txt  xiaoT.txt-- 3个txt结尾的文件,1个sh结尾的文件

实践情况-01:查看所有结尾为txt的文件

tiki wiki[xiaoQ@xiaoq test]$ ls *.txttest.txt  xiaoQ.txt  xiaoT.txt-- 星号可以用于匹配任意开头信息,以指定信息结尾的文件

实践情况-02:查看所有结尾为sh的文件

tiki wiki[xiaoQ@xiaoq test]$ ls *.shxiaoC.sh-- 星号可以用于匹配任意开头信息,以指定信息结尾的文件

实践情况-03:查看所有开头为xiao的文件

tiki wiki[xiaoQ@xiaoq test]$ ls xiao*xiaoC.sh  xiaoQ.txt  xiaoT.txt-- 星号可以用于匹配任意结尾信息,以指定信息开头的文件

实践情况-04:查看所有中间为iao的文件

tiki wiki[xiaoQ@xiaoq test]$ ls *iao*xiaoC.sh  xiaoQ.txt  xiaoT.txt-- 星号可以用于匹配任意字符信息,以含有指定字符信息的文件

实践情况-05:查看所有隐藏文件和含有空格的文件

tiki wiki# 查找指定隐藏文件信息[xiaoQ@xiaoq test]$ touch .xiaoA .xiaoB [xiaoQ@xiaoq test]$ ls ./.*./.xiaoA  ./.xiaoB./.:test.txt  xiaoC.sh  xiaoQ.txt  xiaoT.txt./..:readme  test[xiaoQ@xiaoq test]$ ls ./.x*./.xiaoA  ./.xiaoB# 查找含有空格字符文件[xiaoQ@xiaoq test]$ touch 'xiao X.txt' [xiaoQ@xiaoq test]$ ls xiao*X.txtxiao X.txt
02. ?号的作用详述与实践

在Linux命令行通配符中,?号代表的是任意一个字符(有且只有一个),这个字符在实际工作中运用不多。

实践操作:

实践情况-01:查看所有结尾为.sh的文件

[xiaoQ@xiaoq test]$ lstest.txt  xiaoC.sh  xiaoQ.txt  xiaoT.txt  xiao X.txt[xiaoQ@xiaoq test]$ ls ?.shls: cannot access ?.sh: No such file or directory[xiaoQ@xiaoq test]$ touch a.sh b.sh c.sh[xiaoQ@xiaoq test]$ ls ?.sha.sh  b.sh  c.sh[xiaoQ@xiaoq test]$ ls ?????.shxiaoC.sh
03. [abcd]的作用详述与实践

在Linux命令行通配符中 [] 这个符号里面可以加abcd等0到多个字符,表示匹配abcd的任意一个字符中有且只有一个

实践操作:

实践情况-01:查看所有结尾为.sh的文件

[xiaoQ@xiaoq test]$ ls ?.sha.sh  b.sh  c.sh[xiaoQ@xiaoq test]$ ls [abcd].sh-- 匹配 .sh结尾的,且前面必须包含a b c d四个字符中的任意一个a.sh  b.sh  c.sh[xiaoQ@xiaoq test]$ touch ab.sh[xiaoQ@xiaoq test]$ ls [abcd].sha.sh  b.sh  c.sh-- ab表示两个字符,并不会被中括号中的内容匹配[xiaoQ@xiaoq test]$ ls xi[abcd]oC.shxiaoC.sh-- 匹配oC.sh结尾,开头是xi,之后是a b c d中的任意一个
04. [a-z] 的作用详述与实践

[]这个符号里面的a-z,表示匹配a到z的任意一个字符(有且只有一个),a-z要表示连续,也可以连续数字信息

例如:[1-9]表示的就是匹配1到9中的任意一个字符

实践操作:

实践情况-01:查看所有结尾为.sh的文件

[xiaoQ@xiaoq test]$ ls *.shab.sh  a.sh  b.sh  c.sh  xiaoC.sh[xiaoQ@xiaoq test]$ ls [a-z].sh-- 匹配 .sh结尾,前面值包含a-z之间的任意一个字符a.sh  b.sh  c.sh[xiaoQ@xiaoq test]$ ls [a-z]?.sh-- 匹配a到z之间包含的任意一个字符开头,后面任意1个字符,最后以.sh结尾的文件ab.sh[xiaoQ@xiaoq test]$ ls [a-z]????.shxiaoC.sh-- 匹配a到z之间包含的任意一个字符开头,后面任意4个字符,最后以.sh结尾的文件[xiaoQ@xiaoq test]$ touch 1 2[xiaoQ@xiaoq test]$ ls [1-9]-- 匹配1到9之间的任意一个数字1  2
05. [!abcd] 的作用详述与实践

[!abcd]表示匹配除了abcd四个字符以外的任意一个字符(有且只有一个),也可写成abcda-d

实践操作:

实践情况-01:查找非abcd的单个字符的文件

[xiaoQ@xiaoq test]$ touch a b c d e f[xiaoQ@xiaoq test]$ ls ?1  2  a  b  c  d  e  f[xiaoQ@xiaoq test]$ ls [!abcd]-- 匹配包含a b c d任意字符以外的单个字符文件1  2  e  f[xiaoQ@xiaoq test]$ ls [^abcd]-- 匹配包含a b c d任意字符以外的单个字符文件1  2  e  f[xiaoQ@xiaoq test]$ ls [^a-d]-- 匹配包含a b c d任意字符以外的单个字符文件1  2  e  f[xiaoQ@xiaoq test]$ ls [^1-9]-- 匹配包含1到9任意字符以外的单个字符文件a  b  c  d  e  f

综合练习:

练习-01:查找/etc/目录包含hosts字符串的所有文件

[root@xiaoq ~]# find /etc/ -type f -name "*hosts*"/etc/hosts/etc/hosts.allow/etc/hosts.deny

练习-02:查找/etc目录下的所有文件,文件名的第一个字符为任意字符,第二字符为o p q中的任意一个,第三个字符不能在a到r之间,结尾是ts

[root@xiaoq ~]# find /etc/ -type f -name "?[opq][^a-r]ts"/etc/hosts
06. {}的作用详述与实践

{}在系统中可以用于生成默认字母或数值序列,还可以实现序列信息的组合,以及可以实现加载变量信息

实践操作:

实践情况-01:利用{}生成字符序列信息

# 连续序列[root@xiaoq ~]# echo {1..9}1 2 3 4 5 6 7 8 9[root@xiaoq ~]# echo {a..k}a b c d e f g h i j k# 间隔序列[root@xiaoq ~]# echo {1..9..2}1 3 5 7 9[root@xiaoq ~]# echo {a..k..2}a c e g i k[root@xiaoq ~]# echo {a,f,1,3}a f 1 3

实践情况-02:利用{}实现字符信息组合

[root@xiaoq ~]# echo {1,2}{a,b}1a 1b 2a 2b[root@xiaoq ~]# echo 1{a,b}1a 1b[root@xiaoq ~]# echo {1,2}a1a 2a# 利用序列组合可以实现数据快速备份[root@xiaoq ~]# touch /etc/sysconfig/xiaoQ.conf[root@xiaoq ~]# cp /etc/sysconfig/xiaoQ.conf{,.bak}# 利用序列组合可以实现数据快速还原[root@xiaoq ~]# mv /etc/sysconfig/xiaoQ.conf{.bak,}mv: overwrite ‘/etc/sysconfig/xiaoQ.conf’? y

实践情况-03:将变量括起来作为变量的分割符

[root@xiaoq ~]# num=6[root@xiaoq ~]# echo $num6[root@xiaoq ~]# echo $num_info-- 输出为空,系统将num_info作为变量了[root@xiaoq ~]# echo ${num}_info-- 将变量num括起来单独作为变量,后边_info当成正常字符信息,即可实现信息输出6_info
系统特殊符号介绍1、系统特殊符号简介

相比通配符号来说,Linux特殊符号更加复杂多样,且杂乱无章;因此,为了初学者便于记忆掌握,做了一定分类

系统基础类型特殊符号:; # | $引号类型相关特殊符号:'' "" `` 无引号重定向类型的特殊符号:> >> < << 及特殊情况切换路径相关特殊符号:~ - . ..判断逻辑相关特殊符号:&& || !01.系统基础特殊符号

序号

符号

解释说明

01

;

表示一个命令的结束,也是命令间的分隔符

02

#

表示注释内容,是用来给管理员看的,系统不会执行以#好开头的内容 root用户的命令提示符

03

|

表示管道符号,将一个命令处理后的结果内容输出给下一个命令继续处理

04

$

字符串前加$符号,代表字符串变量内容 代表普通用户的命令提示符

分号的介绍与实践

在Linux命令行中,分号表示一个命令的结束,也是命令间的分隔符;

在有些配置文件中,以分号开头的内容代表注释,例如在keepalived.conf高可用配置中就是如此:

实践操作作用演示:

[root@xiaoq ~]# ll /test -dls: cannot access /test: No such file or directory[root@xiaoq ~]# mkdir /test ; cd /test ; pwd-- 同时执行多个命令:创建指定目录,进入指定目录,并查看所在路径/test[root@xiaoq test]# ll /test/ -ddrwxr-xr-x 2 root root 6 Jan 12 21:39 /test/

井号的介绍与实践

在Linux系统的配置文件中,经常会看到以井号开头的内容,表示后面的注释内容,这部分内容是管理员看的;

系统不会执行以井号开头的内容。

实践操作作用演示:

# 正常编写脚本文件,并触发执行脚本文件[root@xiaoq ~]# cat test_#.sh echo xiaoQ linuxecho xiaoQ pythonecho xiaoQ network[root@xiaoq ~]# sh test_#.sh xiaoQ linuxxiaoQ pythonxiaoQ network# 将脚本文件指定内容加井号注释,再执行脚本文件[root@xiaoq ~]# cat test_#.sh echo xiaoQ linux# echo xiaoQ python#echo xiaoQ network[root@xiaoq ~]# sh test_#.sh xiaoQ linux-- 执行没有井号开头的行会被系统识别

系统中除了脚本文件或代码文件中会用到井号作为注释信息,一些配置文件也会使用井号作为注释信息:

[root@xiaoq ~]# tail /etc/ssh/sshd_config # override default of no subsystemsSubsystem sftp  /usr/libexec/openssh/sftp-server# Example of overriding settings on a per-user basis#Match User anoncvs# X11Forwarding no# AllowTcpForwarding no# PermitTTY no# ForceCommand cvs server

管道符的介绍与实践

在Linux系统命令行中,管道符是极其重要的符号,类似于生活中的管道作用,只不过Linux管道里传输的是数据流;

在实际命令行中,命令处理后在并未得到想要的结果前,可以将数据交给其他命令继续处理,直到得到最终结果为止

一般在命令和命令之间就需要用管道衔接将数据流发过来进行处理。

实践操作作用演示:

[root@xiaoq ~]# ifconfig eth0eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500        inet 10.0.0.101  netmask 255.255.255.0  broadcast 10.0.0.255        inet6 fe80::d349:f92:2e8e:dc7e  prefixlen 64  scopeid 0x20<link>                 ::        ether 00:0c:29:19:74:65  txqueuelen 1000  (Ethernet)        RX packets 1043  bytes 95395 (93.1 KiB)        RX errors 0  dropped 0  overruns 0  frame 0        TX packets 882  bytes 110951 (108.3 KiB)        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0[root@xiaoq ~]# ifconfig eth0|grep 10.0.0        inet 10.0.0.101  netmask 255.255.255.0  broadcast 10.0.0.255

美元符的介绍与实践

在Linux系统命令行或shell脚本程序中,在字符串前加$符号,代表的是字符串变量的内容。

实践操作作用演示:

[root@xiaoq ~]# echo $OLDPWD/test[root@xiaoq ~]# echo $PWD/root[root@xiaoq ~]# echo $PATH/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin[root@xiaoq ~]# xiaoQ=1[root@xiaoq ~]# echo $xiaoQ1
02.引号类型特殊符号

序号

符号

解释说明

01

单引号 ''

所见即所得,即输入单引号内容时会将单引号内的所有内容都原样输出; 或者描述为单引号里面看到的是什么就会输出什么,称为强引用

02

双引号 ""

输出双引号内的所有内容时,如果内容中有变量、特殊字符等信息; 会将变量、特殊字符等信息解析出结果,然后在输出,称为弱引用

03

无引号

基本和有双引号的作用功能一致;只是在有空格字符存在时,需要使用双引号; 当需要生成序列信息时,需要使用无引号情况

04

反引号

一般用于引用命令,执行的时候命令会被执行,相当于"$()" 赋值和输出都要将命令用反引号引起来

单引号的介绍与实践

简单来说,当待处理的内容用单引号引起来时,引号里面有什么内容,处理时就一直保持引号之前的内容不变。

实践操作作用演示:

[root@xiaoq ~]# echo '$PATH'$PATH[root@xiaoq ~]# echo '`date`'`date`

双引号的介绍与实践

当输出双引号内的所有内容时,会先将变量或特殊字符解释出来,然后输出最终的内容;

若在平时引用字符串时,不知如何应用引号符号,则可默认使用双引号。

实践操作作用演示:

[root@xiaoq ~]# echo "$PATH"/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin[root@xiaoq ~]# echo "`date`"Thu Dec 12 00:00:07 CST 2222[root@xiaoq ~]# echo "xiaoQ"xiaoQ

无引号的介绍与实践

不使用引号的功能与双引号类似,但由于没有引号,在引用字符串信息时,很难确定字符串的边界;

因此很容易出现各种未知的操作错误,所以建议处理字符串内容是建议使用双引号替代不加引号情况

实践操作作用演示:

[root@xiaoq ~]# echo "dir info $PWD"dir info /root[root@xiaoq ~]# echo dir info $PWDdir info /root-- 输出加载指定信息,无引号和双引号功能类似[root@xiaoq ~]# xiaoQ=linux 123-bash: 123: command not found[root@xiaoq ~]# xiaoQ="linux 123"-- 变量赋值时,字符串中有空格出现无引号情况无法确认边界情况,会赋值报错[root@xiaoq ~]# echo {1..5}1 2 3 4 5[root@xiaoq ~]# echo "{1..5}"{1..5}-- 加载{}生成序列信息时,是不需要使用双引号的

反引号的介绍与实践

简单来说,当将带处理的字符串用反引号引起来的时候,系统会先将反引号里字符串当做命令进行解析识别;

然后针对解析后的结果做进一步的处理。反引号一般用于引用命令,执行的时候命令会被执行,等价于$()。

实践操作作用演示:

[root@xiaoq ~]# dateThu Dec 12 00:00:21 CST 2222[root@xiaoq ~]# echo datedate[root@xiaoq ~]# echo `date`Thu Dec 12 00:00:40 CST 2222-- 可以识别解析命令信息[root@xiaoq ~]# echo `aa`-bash: aa: command not found-- 反引号中只能解析识别有效的命令[root@xiaoq ~]# host_info=`hostname`[root@xiaoq ~]# echo $host_info xiaoq.edu-- 做赋值操作时,也可以使用反引号解析命令后的结果再赋值[root@xiaoq ~]# cp /etc/hosts /data/hosts-`date +%F`[root@xiaoq ~]# ll /data/hosts-`date +%F`-rw-r--r-- 1 root root 180 Dec 12 00:02 /data/hosts-2222-12-12-- 企业中做数据备份时,经常会用到反引号
03.重定向类型特殊符号

重定向是Linux里的一个重要名词,对于它的作用,就是类似于生活中的漏斗一样;

可以让数据从一个地方无损失地流到另一个地方。

序号

名称

解释说明

01

标准输入(stdin)

代码为0,配合<或<<使用 数据流从右向左

02

标准输出(stdout)

代码为1,配合>或>>使用 数据流从左向右

03

标准错误(stderr)

代码为2,配合2>或2>>使用 数据流从左向右

详细类型解读

01

标准输入重定向

0<或< 清空已有内容,数据一般从文件流向处理命令

02

追加输入重定向

0<<或<< 追加内容到底部,数据一般从文件流向处理命令

03

标准输出重定向

1>或> 正确输出重定向到文件,会清空已有的内容

04

标准输出追加重定向

1>>或>> 将内容追加重定向到文件底部,不会清空已有的内容

05

错误输出重定向

2> 将标准错误内容重定向到文件,如果文件存在内容则清空

06

标准错误输出追加重定向

2>> 将标准错误内容追加到文件底部,不会清空已有的内容

标准输入介绍与实践

利用标准输入,可以将指定的文件内容信息调取出来,让命令进行加载处理,可以是覆盖输入或追加输入;

# 标准输入方式读取文件内容[root@xiaoq ~]# echo 1 2 3 > xiaoQ.txt[root@xiaoq ~]# cat xiaoQ.txt 1 2 3[root@xiaoq ~]# cat<xiaoQ.txt1 2 3[root@xiaoq ~]# cat 0<xiaoQ.txt1 2 3# 标准输入方式处理文件内容[root@xiaoq ~]# tr " " "\n" <xiaoQ.txt 123[root@xiaoq ~]# xargs -n 1 <xiaoQ.txt 123[root@xiaoq ~]# mail -s '邮件标题' 邮件地址 <邮件内容(文件)[root@xiaoq ~]# mail -s 'test mail' xiaoQ@qq.com </etc/hosts# 标准输入追加重定向[root@xiaoq ~]# cat <<EOFxiaoQEOFxiaoQ-- 读入数据输出到屏幕[root@xiaoq ~]# cat >xiaoQ.txt<<EOF> xiaoQ> xiaoA> xiaoB> EOF-- 读入数据输出到指定文件[root@xiaoq ~]# cat xiaoQ.txt xiaoQxiaoAxiaoB

标准输出介绍与实践

利用标准输出,可以将指定的数据内容信息输出到指定文件中,实现对特定数据信息的永久保留,便于分析查看;

# 标准输出重定向[root@xiaoq ~]# echo "123" 1>xiaoQ.txt[root@xiaoq ~]# cat xiaoQ.txt 123[root@xiaoq ~]# mkdir -v /test_dir >xiaoQ.txt[root@xiaoq ~]# cat xiaoQ.txt mkdir: created directory ‘/test_dir’# 可以实现清空文件数据内容[root@xiaoq ~]# cat xiaoQ.txt 123[root@xiaoq ~]# cat /dev/null >xiaoQ.txt 或者[root@xiaoq ~]# >xiaoQ.txt[root@xiaoq ~]# cat xiaoQ.txt -- 清空文件操作,多用于对系统日志文件清理操作# 标准追加输出重定向[root@xiaoq ~]# echo 123 >>xiaoQ.txt[root@xiaoq ~]# echo 456 >>xiaoQ.txt[root@xiaoq ~]# echo 789 >>xiaoQ.txt[root@xiaoq ~]# cat xiaoQ.txt 123456789

错误输出介绍与实践

利用错误输出,可有将指定命令或程序执行过程中出现的错误提示信息输出到指定文件中,便于对操作进行复盘;

[root@xiaoq ~]# mkdir /test_dirmkdir: cannot create directory ‘/test_dir’: File exists[root@xiaoq ~]# mkdir /test_dir 2> xiaoQ.txt[root@xiaoq ~]# cat xiaoQ.txt mkdir: cannot create directory ‘/test_dir’: File exists

标准输出与错误输出结合使用:(生成日志文件的机制)

# 方法一:1>>文件 2>>文件[root@xiaoq ~]# mkdir -v /test_dir 1>>xiaoQ.txt  2>>xiaoQ.txt[root@xiaoq ~]# mkdir -v /test_dir 1>>xiaoQ.txt  2>>xiaoQ.txt[root@xiaoq ~]# cat xiaoQ.txt mkdir: created directory ‘/test_dir’mkdir: cannot create directory ‘/test_dir’: File exists# 方法二:2>&1[root@xiaoq ~]# mkdir -v /test_dir >>xiaoQ.txt  2>&1[root@xiaoq ~]# mkdir -v /test_dir >>xiaoQ.txt  2>&1[root@xiaoq ~]# cat xiaoQ.txt mkdir: created directory ‘/test_dir’mkdir: cannot create directory ‘/test_dir’: File exists# 方法三:&>> ※[root@xiaoq ~]# mkdir -v /test_dir &>>xiaoQ.txt[root@xiaoq ~]# mkdir -v /test_dir &>>xiaoQ.txt[root@xiaoq ~]# cat xiaoQ.txtmkdir: created directory ‘/test_dir’mkdir: cannot create directory ‘/test_dir’: File exists

知识点总结:

标准输入:表示将数据从文件中流入到处理的命令中,用代码0表示,使用<或<<符号来指示数据的流向;标准输出:表示将命令处理的信息输出到指定文件中,用代码1表示,使用>或>>符号来指示数据的流向;错误输出:表示将命令操作错误的信息输出到文件中,用代码2表示,使用2>或2>>符号来指示数据的流向;04.路径切换特殊符号

序号

符号

解释说明

01

~

快速切换到用户的家目录,超级用户为root;普通用户为/home/用户名称目录;

02

-

切换到上一次(相对当前路径)用户所在的路径

03

.

代表当前目录(点号还有很多其他含义,需要注意)

04

..

代表上一级目录

波浪线介绍与实践

在Linux系统命令行中,~代表用户的家目录:

实践操作作用演示:

[root@xiaoq etc]# pwd/etc[root@xiaoq etc]# cd ~[root@xiaoq ~]# pwd/root[root@xiaoq ~]# cd /etc/[root@xiaoq etc]# pwd/etc[root@xiaoq etc]# cd-- cd命令后什么信息都不加,也等价于cd ~作用[root@xiaoq ~]# pwd/root

短横线介绍与实践

在Linux系统命令行中,短横线代表上一次用户所在的路径。

实践操作作用演示:

# 操作过程演示[root@xiaoq ~]# cd /etc/[root@xiaoq etc]# [root@xiaoq etc]# cd -/root[root@xiaoq ~]# pwd/root[root@xiaoq ~]# cd -/etc[root@xiaoq etc]# pwd/etc# 操作过程机制[root@xiaoq ~]# echo $OLDPWD/etc[root@xiaoq ~]# cd -/etc[root@xiaoq etc]# echo $OLDPWD/root[root@xiaoq etc]# cd $OLDPWD[root@xiaoq ~]# pwd/root

点符号介绍与实践

在Linux系统命令行中,点号代表当前目录。

实践操作作用演示:

[root@xiaoq etc]# pwd/etc[root@xiaoq etc]# cd .[root@xiaoq etc]# pwd/etc[root@xiaoq etc]# find . -name "*.sh"  ./dhcp/dhclient-exit-hooks.d/azure-cloud.sh[root@xiaoq etc]# rm ./xiaoQ* -rf

双点号介绍与实践

在Linux系统命令行中,双点号代表当前目录的上一级目录。

实践操作作用演示:

[root@xiaoq etc]# pwd/etc[root@xiaoq etc]# cd ..[root@xiaoq /]# pwd/[root@xiaoq /]# ls -a /test_dir/.  ..
05.逻辑相关特殊符号

序号

符号

解释说明

01

&&

前一个命令执行成功,再执行后面一个命令

02

||

前一个命令执行失败,再执行后面一个命令

03

!

在命令执行中有取反作用 find . ! -name "xiaoQ" 在vi/vim中表示强制作用 wq! 在命令前加!表示找出最近一次以指定开头的命令并执行(慎用)

逻辑符号多用于后续课程的shell脚本编写中,命令行应用情况比较少见,此时作为了解即可。

逻辑符号&&介绍与实践

在Linux系统中表示,判断前一个操作是否成功,如果成功再进行后续的操作;

[root@xiaoq /]# # 有钱 -- 买房[root@xiaoq /]# rm -rf /test_dir/[root@xiaoq /]# mkdir /test_dir && cd /test_dir-- 创建目录成功后,才会切换目录[root@xiaoq test_dir]# pwd/test_dir[root@xiaoq test_dir]# cd [root@xiaoq ~]# mkdir /test_dir && cd /test_dir/mkdir: cannot create directory ‘/test_dir’: File exists-- 创建目录失败后,就不会切换目录[root@xiaoq ~]# [root@xiaoq ~]# mkdir /test_dir ; cd /test_dir/mkdir: cannot create directory ‘/test_dir’: File exists-- 对比分号操作,分号分割的多个命令,没有逻辑概念,会同时执行

逻辑符号||介绍与实践

在Linux系统中表示,判断前一个操作是否失败,如果失败再进行后续的操作;

[root@xiaoq ~]# mkdir /test_dir || echo "dir create error"                      ||mkdir: cannot create directory ‘/test_dir’: File existsdir create error-- 创建失败,会执行的操作[root@xiaoq ~]# rm /test_dir/ -rf[root@xiaoq ~]# mkdir /test_dir || echo "dir create error"                      ||-- 创建成功,就不会执行指定操作

逻辑符号组合使用情况

判断成功和判断失败逻辑符号也可以组合使用,实现多种情况的灵活处理;

[root@xiaoq ~]# #  && || -- 钱 -- 有钱 && 生活轻松 没钱 || 努力奋斗   [root@xiaoq ~]# rm /test_dir/ -rf[root@xiaoq ~]# mkdir /test_dir && echo "目录创建成功" || echo "目录创建失败"     ||目录创建成功-- 目录创建成功处理方案[root@xiaoq ~]# mkdir /test_dir && echo "目录创建成功" || echo "目录创建失败"     ||mkdir: cannot create directory ‘/test_dir’: File exists目录创建失败-- 目录创建失败处理方法
系统正则符号介绍1、正则符号简介说明

简单地说,正则表达式符号就是为处理大量的字符串及文本而定义的一套规则和方法;

通过这些正则符号,管理员可以快速过滤,替换或输出所需要的字符串。使运维工作更加高效。

正则表达式符号应用非常广泛,存在于各种语言之中,例如 python java go等语言中都存在;

但是Linux运维人员只要掌握bash解释器环境中的正则表达式用法即可,即可三剑客grep sed awk命令,

进行有效的应用,从而提高工作效率即可。

在学习掌握正则表达式时,需要注意以下几点:

正则表达式是以行为单位进行处理的;正则表达式仅适用于三剑客命令加载识别(grep sed awk);正则表达式使用时,主要LC_ALL环境变量要设置为LC_ALL=C;2、正则符号分类介绍

Linux的正则表达式可分为两类:

基础正则表达式(BRE basic regular expression)

对应的正则符号:^$.[]*; 通常默认可以直接被三剑客命令识别;

扩展正则表达式(ERE extended regular expression)

对应的正则符号:(){}?+|;三剑客命令在加载识别时,除awk命令可以直接识别,grep和sed命令都要加指定参数识别

3、基础正则符号简介

序号

基础正则符号

解释说明

01

^

尖角号,用法为"^xiaoQ",表示匹配以xiaoQ单词开头的行

02

$

美元符,用法为"xiaoQ$",表示匹配以xiaoQ单词结尾的行

03

^$

组合符,表示空行,逻辑解释就是以^结尾的行,以$开头的行

04

.

点符号,表示匹配任意一个且只有一个字符(但不能匹配空行)

05

\

转义符,让有特殊含义的字符还原本意;让没特殊含义字符赋予特殊含义

06

*

星符号,匹配前一个字符(连续出现)0次或1次以上 注意:当重复0次的时候,表示什么也没有,即匹配所有内容

07

.*

组合符,匹配所有内容 包含空行信息

08

^.*

组合符,匹配以任意多个字符开头的内容

09

.*$

组合符,匹配以任意多个字符结尾的内容

10

[abc]

匹配[]集合内的任意一个字符a或b或c;[abc]也可写成[a-c]

11

[^abc]

匹配不包含^号后的任意字符a或b或c,这里的^表示对[abc]取反 注意:此处不能用!替代

以上基础正则符号会分为三个部分学习01-05 06-09 10-11;要以视频操作显示的信息为主

4、基础正则符号实践

基础正则符号实践操作环境准备:

[root@xiaoq ~]# mkdir ~/test[root@xiaoq ~]# cd  ~/test[root@xiaoq test]# cat >~/test/xiaoQ.txt<<EOFI am xiaoQ teacher!I teach linux. I like badminton ball ,billiard ball and chinese chess!my qq num is 3052869928. not 3052869999928.my god ,i am not xiaoB,but XIAOQEOF[root@xiaoq test]# cat -n xiaoQ.txt      1	I am xiaoQ teacher!     2	I teach linux.     3	     4	I like badminton ball ,billiard ball and chinese chess!     5	my qq num is 3052869928.     6	     7	not 3052869999928.     8	my god ,i am not xiaoB,but XIAOQ
基础正则符号功能实践-^

尖角符号表示匹配每行以指定字符开头的信息;

实践操作作用演示:输出以m开头的所有行并打印行号

[root@xiaoq test]# grep -n "^m" xiaoQ.txt 5:my qq num is 3052869928.8:my god ,i am not xiaoB,but XIAOQ

若没特殊需求,建议用双引号将过滤的内容引用起来,否则可能会遇到异常问题。

基础正则符号功能实践-$

美元符号表示匹配每行以指定字符结尾的信息;

实践操作作用演示:输出以Q结尾的所有行并打印行号

[root@xiaoq test]# grep "Q$" xiaoQ.txt my god ,i am not xiaoB,but XIAOQ[root@xiaoq test]# grep -i "q$" xiaoQ.txt my god ,i am not xiaoB,but XIAOQ[root@xiaoq test]# grep "Q$" xiaoQ.txt|cat -Amy god ,i am not xiaoB,but XIAOQ$
基础正则符号功能实践-^$

实践操作作用演示:过滤出空行信息

[root@xiaoq test]# grep -n "^$" xiaoQ.txt 3:                                                                                   6:

实践操作作用演示:过滤除空行以外信息

[root@xiaoq test]# grep -nv "^$" xiaoQ.txt 1:I am xiaoQ teacher!2:I teach linux.4:I like badminton ball ,billiard ball and chinese chess!5:my qq num is 3052869928.7:not 3052869999928.8:my god ,i am not xiaoB,but XIAOQ

当^开头与$结尾连在一起时,解可以理解为开头到结尾中间没有任何数据内容,即表示的就是空行。

基础正则符号功能实践-.

点符号表示匹配任意一个字符(有且只有一个),但不包含空行。

实践操作作用演示:匹配任意一个字符并输出对应文件中的行号

[root@xiaoq test]# grep -n "." xiaoQ.txt 1:I am xiaoQ teacher!2:I teach linux.4:I like badminton ball ,billiard ball and chinese chess!5:my qq num is 3052869928.7:not 3052869999928.8:my god ,i am not xiaoB,but XIAOQ

匹配任意一个字符,所以文件的内容都出来了,但是上面找到的内容不包含空行。

思考:点表示匹配任意字符,并且匹配且只有一个字符,怎么文件所有字符都出来了?

实践操作作用演示:显示以点结尾的行

[root@xiaoq test]# grep -n ".$" xiaoQ.txt 1:I am xiaoQ teacher!2:I teach linux.4:I like badminton ball ,billiard ball and chinese chess!5:my qq num is 3052869928.7:not 3052869999928.8:my god ,i am not xiaoB,but XIAOQ

.$表示的是以任意单个字符结尾的行,因此结果并不是需求的目标。

基础正则符号功能实践-\

转义符号主要用途是让有特殊含义的符号变为一般符号,当然也可以将没有作用的字符变为有特殊意义;

实践操作作用演示:显示以点结尾的行

[root@xiaoq test]# grep -n "\.$" xiaoQ.txt 2:I teach linux.5:my qq num is 3052869928.7:not 3052869999928.

实践操作作用演示:转义特殊字符信息

[root@xiaoq test]# echo  "xiaoQnlinux"xiaoQnlinux[root@xiaoq test]# echo -e "xiaoQ\nlinux"xiaoQlinux[root@xiaoq test]# echo -e "xiaoQ\tlinux"xiaoQ	linux
基础正则符号功能实践-*

星号表示匹配前一个字符0次或0次以上的数据内容;

实践操作作用演示:输出文件中连续出现了0次或0次以上的数字9的内容

[root@xiaoq test]# grep "9*" xiaoQ.txt I am xiaoQ teacher!I teach linux.I like badminton ball ,billiard ball and chinese chess!my qq num is 3052869928.not 3052869999928.my god ,i am not xiaoB,but XIAOQ-- 每行中没有出现9字符,就表示出现0次,也会匹配,所以所有文件内容都会显示[root@xiaoq test]# grep "9" xiaoQ.txt my qq num is 3052869928.not 3052869999928.-- 单独过滤数字9,只有含有9字符的行会出现,没有9字符(出现0次的)不会显示
基础正则符号功能实践-.*

.*组合使用时表示匹配所有字符,包含空行。

实践操作作用演示:通过grep显示文件的所有内容,包含空行

[root@xiaoq test]# grep ".*" xiaoQ.txt I am xiaoQ teacher!I teach linux.I like badminton ball ,billiard ball and chinese chess!my qq num is 3052869928.not 3052869999928.my god ,i am not xiaoB,but XIAOQ[root@xiaoq test]# grep "." xiaoQ.txt I am xiaoQ teacher!I teach linux.I like badminton ball ,billiard ball and chinese chess!my qq num is 3052869928.not 3052869999928.my god ,i am not xiaoB,but XIAOQ

虽然.*和. 都可以将文件中的所有信息进行匹配显示,但是还是有本质区别的,利用grep -o参数可以看出其中奥秘

[root@xiaoq test]# grep -o  ".*" xiaoQ.txt I am xiaoQ teacher!I teach linux.I like badminton ball ,billiard ball and chinese chess!my qq num is 3052869928.not 3052869999928.my god ,i am not xiaoB,but XIAOQ[root@xiaoq test]# grep -o  "." xiaoQ.txt I am xia

grep -o参数可以将每次匹配的信息按行单独显示,具体说明每次匹配的内容。

实践操作作用演示:匹配开头所有字符,每行到o字符结束/匹配从o开始到指定最后字符结束

[root@xiaoq test]# grep   "^.*o" xiaoQ.txt I am xiaoQ teacher!I like badminton ball ,billiard ball and chinese chess!not 3052869999928.my god ,i am not xiaoB,but XIAOQ[root@xiaoq test]# grep "o.*$" xiaoQ.txt I am xiaoQ teacher!I like badminton ball ,billiard ball and chinese chess!not 3052869999928.my god ,i am not xiaoB,but XIAOQ

已经实现了匹配任意多个字符开头一直到第一个字母o为止的内容;

但可以看出实际上匹配到了每一行的最后一个字符o,因为正则符号匹配信息以行为单位并且具有贪婪特性。

基础正则符号功能实践-[]

中括号表示匹配其中的任何一个字符,[abc]会匹配a或b或c

匹配方式有:

序号

匹配方式

解释说明

01

[a-z]

表示匹配所有单个小写字母

02

[A-Z]

表示匹配所有单个大写字母

03

[a-zA-Z]或[a-Z]

表示匹配所有单个英文字母(包含大小写所有字母)

04

[0-9]

表示匹配所有单个数字

05

[a-zA-Z0-9]

表示匹配所有字母和数字

实践操作作用演示:匹配文件中所有的大写字母

[root@xiaoq test]# grep '[A-Z]' xiaoQ.txt I am xiaoQ teacher!I teach linux.I like badminton ball ,billiard ball and chinese chess!my god ,i am not xiaoB,but XIAOQ

实践操作作用演示:匹配字符串xiaoQ信息

[root@xiaoq test]# grep '[xiaoQ]' xiaoQ.txt I am xiaoQ teacher!I teach linux.I like badminton ball ,billiard ball and chinese chess!my qq num is 3052869928.not 3052869999928.my god ,i am not xiaoB,but XIAOQ[root@xiaoq test]# grep 'xiaoQ' xiaoQ.txt I am xiaoQ teacher!

中括号里面的字符会单个进行匹配,并不是看成一个整体进行匹配。

基础正则符号功能实践-[^]

表示将中括号中的每个字符进行取反匹配;

实践操作作用演示:匹配除了小写字母以外的字符

[root@xiaoq test]# grep "[^a-z]" xiaoQ.txt I am xiaoQ teacher!I teach linux.I like badminton ball ,billiard ball and chinese chess!my qq num is 3052869928.not 3052869999928.my god ,i am not xiaoB,but XIAOQ
5、扩展正则符号简介

序号

扩展正则符号

解释说明

01

+

匹配前一个字符出现1次或多次情况

02

[ab]+

匹配中括号内a或b字符出现1次或多次情况

03

?

匹配前一个字符出现0次或1次情况

04

|

表示或者,即同时过滤多个字符串

05

()

分组过滤,被括起来的内容表示一个整体

06

a{n,m}

匹配前一个字符出现最少n次,最多m次

07

a{n,}

匹配前一个字符出现最少n次

08

a{n}

匹配前一个字符出现正好n次

09

a{,m}

匹配前一个字符最多出现m次

由于以上信息为扩展正则, 利用grep命令识别扩展正则符号需要使用-E参数或者直接使用egrep命令进行过滤.

6、扩展正则符号实践

扩展正则符号实践操作环境准备:

# 测试实践环境准备:[root@xiaoq test]# cat > xiaoT.txt<<EOF> gd> god> good> goood> gooood> goooood> EOF[root@xiaoq test]# cat xiaoT.txt gdgodgoodgooodgoooodgoooood
扩展正则符号功能实践-+

加号表示匹配前一个字符出现1次或1次以上情况, 与基础正则里的* 类似, 只不过比 * 少了一个匹配0次

实践操作作用演示:匹配文件中出现o字符的情况

# 匹配连续出现的o字符信息[root@xiaoq test]# grep "o*" xiaoT.txt gdgodgoodgooodgoooodgoooood-- 匹配o出现0次或连续出现多次的情况[root@xiaoq test]# grep "o+" xiaoT.txt -- 扩展正则符号识别时. grep命令加-E参数或直接使用egrep命令[root@xiaoq test]# grep -E "o+" xiaoT.txt godgoodgooodgoooodgoooood-- 匹配o出现1次或连续出现多次的情况
扩展正则符号功能实践-?

问号表示匹配前一个字符出现0次或1次

实践操作作用演示:匹配文件中包含gd或god的信息

[root@xiaoq test]# grep -E "go?d" xiaoT.txt gdgod-- g和d间出现0次或1次o字符情况[root@xiaoq test]# grep -E "go+d" xiaoT.txt godgoodgooodgoooodgoooood-- g和d间出现1次或多次o字符情况[root@xiaoq test]# grep -E "go*d" xiaoT.txt gdgodgoodgooodgoooodgoooood-- g和d间出现0次或多次o字符情况
扩展正则符号功能实践-|

竖线在扩展正则中表示或者, 可以实现过滤多个字符信息

实践操作作用演示:只过滤文件中good和goood字符串信息

[root@xiaoq test]# grep -E "good|goood" xiaoT.txt goodgoood# 企业环境应用[root@xiaoq ~]# grep -E "faild|error" /var/log/server.log-- 分析日志文件时, 就会用到多个关键信息进行筛选匹配的情况
扩展正则符号功能实践-()

小括号表示可以实现分组过滤被括起来的内容, 括号内的信息表示一个整体

实践操作作用演示:取出包含good或glad的信息

# 测试实践环境调整:[root@xiaoq test]# echo "glad" >>xiaoT.txt [root@xiaoq test]# cat xiaoT.txt gdgodgoodgooodgoooodgooooodglad# 匹配good或glad的信息[root@xiaoq test]# grep -E "goo|lad" xiaoT.txt goodgooodgoooodgooooodglad[root@xiaoq test]# grep -E "g(oo|la)d" xiaoT.txt goodglad
扩展正则符号功能实践-{n,m} {n,} {n} {,m}

实践操作作用演示:匹配字符o, 连续出现3到5次的信息

[root@xiaoq test]# grep -E "o{3,5}" xiaoT.txt gooodgoooodgoooood

实践操作作用演示:匹配字符o, 连续最少出现3次的信息

[root@xiaoq test]# grep -E "o{3,}" xiaoT.txt gooodgoooodgoooood

实践操作作用演示:匹配字符o, 连续正好出现3次的信息

[root@xiaoq test]# grep -E "o{3}" xiaoT.txt gooodgoooodgoooood

实践操作作用演示:匹配字符o, 连续最多出现5次的信息

[root@xiaoq test]# grep -E "o{,5}" xiaoT.txt gdgodgoodgooodgoooodgooooodglad

标签: #正则表达式适用范围