shell脚本(14)-正则表达式
一、正则表达式介绍
正则表达式是一种文本模式匹配,包括普通字符(a...z)和特殊字符(元字符)。
它是一种字符串匹配模式,可以用来检查一个字符串是否含有某种子串、将匹配的子串替换或者从某个字符串中取出某个条件的子串
shell支持正则表达式,但是不是所有的命令都支持正则,常见的命令中只有grep、sed、awk命令支持正则表达式
二、特殊字符
1、定位符使用-模糊匹配与精准匹配:
同时锚定开头和结尾,做精确匹配;单一锚定开发和结尾,做模糊匹配。
| 定位符 | 说明 |
| ^ | 锚定开头^a以a开发,默认锚定一个字符 |
| $ | 锚定结尾a$以a结尾,默认锚定一个字符 |
举例说明:定位符
[root@localhost test20210731]# egrep "^abbbc$" file #正则匹配,等价于grep -e 或 grep -E,精确匹配
abbbc
[root@localhost test20210731]# egrep "^ab" file #匹配开头为ab
abbbc
abababa
abC
[root@localhost test20210731]# egrep "bb$" file #匹配结尾为bb
aabb
&abbb
bbbb
2、匹配符-匹配字符串:
| 匹配符 | 说明 |
| . | 匹配除回车以外的任意字符 |
| () | 字符串分组 |
| [] | 定义字符串,匹配括号中的一个字符 |
| [^] | 表示否定括号中出现字符串的字符,取反 |
| \ | 转义字符 |
| | | 管道-或,结合分组使用 |
举例说明匹配符:
[root@localhost test20210806]# egrep "^a.c$" file #匹配a开头,c结尾,中间任意字符
aBc
aYc
a*c
a4c
a9c
a7c
[root@localhost test20210801]# egrep "^a[0-9]c$" file #匹配a开头c结尾,中间的字符为0-9
a4c
a9c
a7c
[root@localhost test20210801]# egrep "^a[^0-9]c$" file #匹配a开头c结尾,中间非数字
aBc
aYc
a*c
[root@localhost test20210801]# egrep "^a\*c$" file #精确匹配a*c的情况
a*c
[root@localhost test20210801]# egrep "^a*c$" file #不加转义无法匹配
ac
[root@localhost test20210801]# egrep "^(a|b)c$" file #精确匹配以a或b开头,c结尾
ac
bc
3、限定符-对前面的符合或字符串做限定说明
| 限定符 | 说明 |
| * | 某个字符之后加星号表示该字符不出现或出现多次 |
| ? | 与型号类似,但略有不行,表示该字符出现一次或不出现 |
| + | 与星号类似,表示其前面字符出现一次或多次,但是至少出现一次 |
| {n,m} | 某个字符之后出现,表示该字符最少n次,最多m次 |
| {m} | 某个字符出现m次 |
举例说明限定符:
[root@localhost test20210806]# egrep "^ab*c$" file #ab字符中匹配有b(全部需要是b)或没有b
abbbc
ac
[root@localhost test20210806]# egrep "^ab*c$" file #ab字符中匹配有b(全部需要是b)或没有b
abbbc
ac
abc
[root@localhost test20210806]# egrep "^ab?c$" file #ab字符中匹配有b(出现一次)或没有b
ac
abc
[root@localhost test20210806]# egrep "^ab+c$" file #ac字符中匹配有b(至少出现一次)
abbbc
abc
[root@localhost test20210806]# egrep "^ab*c$" file #ac字符中匹配有b(全部需要是b)或没有b
abbbc
ac
abc
[root@localhost test20210806]# egrep "^ab?c$" file #ac字符中匹配有b(出现一次)或没有b
ac
abc
[root@localhost test20210806]# egrep "^ab+c$" file #ac字符中匹配有b(至少出现一次)
abbbc
abc
[root@localhost test20210806]# egrep "^ab{1,3}c$" file #ac字符中匹配有b(出现在1次到3次内)
abbbc
abc
[root@localhost test20210806]# egrep "^ab{3}c$" file #ac字符中匹配有b(正好出现3次)
abbbc
三、POSIX字符
| 特殊字符 | 说明 |
| [:alnum:] | 匹配任意字母字符0-9 a-z A-Z |
| [:alpha:] | 匹配任意字母,大写或小写 |
| [:dight:] | 数字0-9 |
| [:graph:] | 非空字符(非空格控制字符) |
| [:lower:] | 小写字符a-z |
| [:upper:] | 大写字符A-Z |
| [:cntrl:] | 控制字符 |
| [:print:] | 非空字符(包括空格) |
| [:punct:] | 标点符号 |
| [:blank:] | 空格和TAB字符 |
| [:xdigit:] | 16进制数字 |
| [:space:] | 所有空白字符(新行、空格、制表符) |
注意:[[]]双中括号的意思:第一个中括号是匹配符[]匹配中括号中的任意一个字符,第二个[]格式如[:digit:]
举例说明:
[root@localhost tesr20210807]# egrep "^a[[:alnum:]]c$" file #a开头c结尾,中间一个字符匹配非特殊符号
aBc
aYc
a4c
a9c
a7c
abc
[root@localhost tesr20210807]# egrep "^a[[:alnum:]]c$" file #a开头c结尾,中间一个字符匹配任意字母
aBc
aYc
a4c
a9c
a7c
abc
[root@localhost tesr20210807]# egrep "^a[[:alnum:]]c$" file #a开头c结尾,中间一个字符匹配非特殊符号
aBc
aYc
a4c
a9c
a7c
abc
[root@localhost tesr20210807]# egrep ^C]c$" file #a开头c结尾,中间一个字符匹配任意字母
[root@localhost tesr20210807]# egrep "^a[[:alnum:]]c$" file #a开头c结尾,中间一个字符匹配非特殊符号
aBc
aYc
a4c
a9c
a7c
abc
[root@localhost tesr20210807]# egrep "^a[[:alpha:]]c$" file #a开头c结尾,中间一个字符匹配任意字母
aBc
aYc
abc
[root@localhost tesr20210807]# egrep "^a[[:digit:]]c$" file #a开头c结尾,中间一个字符匹配任意数字
a4c
a9c
a7c
[root@localhost tesr20210807]# egrep "^a[[:graph:]]c$" file #a开头c结尾,中间一个字符匹配非空字符
aBc
aYc
a*c
a4c
a9c
a7c
abc
a,c
[root@localhost tesr20210807]# egrep "^a[[:lower:]]c$" file #a开头c结尾,中间一个字符匹配小写字母
abc
[root@localhost tesr20210807]# egrep "^a[[:upper:]]c$" file #a开头c结尾,中间一个字符匹配大写字母
aBc
aYc
[root@localhost test20210807]# egrep "^a[[:blank:]]c$" file #a开头c结尾,中间一个字符为空格或TAB
a c
a c
[root@localhost test20210807]# egrep "^a[[:space:]]c$" file #a开头c结尾,中间匹配所有空白、空行、制表符
a c
a c
[root@localhost test20210807]# egrep "^a[[:blank:]]c$" file #a开头c结尾,中间一个字符为空格或TAB
a c
a c
[root@localhost test20210807]# egrep "^a[[:space:]]c$" file #a开头c结尾,中间匹配所有空白、空行、制表符
a c
a c
[root@localhost test20210807]# egrep "^a[[:blank:]]c$" file #a开头c结尾,中间一个字符为空格或TAB
a c
a c
[root@localhost test20210807]# egrep "^a[[:space:]]c$" file #a开头c结尾,中间一个字符匹配空白、空行、制表符
a c
a c
[root@localhost test20210807]# egrep "^a[[:punct:]]c$" file #a开头c结尾,中间一个字符匹配标点符号
a*c
a,c
[root@localhost test20210807]# egrep "^a[[:print:]]c$" file #a开头c结尾,中间一个字符匹配非空字符(含括号)
aBc
aYc
a*c
a4c
a9c
a7c
abc
a c
a,c
[root@localhost test20210807]# egrep "^a[[:xdigit:]]c$" file #a开头c结尾,中间一个字符匹配十六进制数
aBc
a4c
a9c
a7c
abc
四、常见正则匹配:
1、数字:^[0-9]*$
2、汉字:^[\u4e00-\u9fa5]{0,}$
3、英文字母:^[A-Za-z]+$
4、手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$
5、IP地址:((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))
更多正则表达式参考:
shell脚本(14)-正则表达式的更多相关文章
- shell脚本三——正则表达式
shell函数:shell中允许将一组命令集合或语句形成一段可用代码,这些代码块称为shell函数.给这段代码起个名字称为函数名,后续可以直接调用该段代码. 格式:fun() { 命令 } Shell ...
- shell脚本学习—正则表达式
正则表达式概念.特点 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”, 这个“规则字符串”用来表达对字符串的一种过滤辑. 给定一个 ...
- shell脚本之正则表达式
具体参考: www.jb51.net/tools/shell_regex.html 正则表达式常用于grep AWK 等工具中
- 学习笔记之Shell脚本学习指南 & sed与awk & 正则表达式
正则表达式_百度百科 http://baike.baidu.com/link?url=ybgDrN2WQQKN64_gu-diCqdeDqL8LQ-jiQ-ftzzPaNUa9CmgBRDNnyx50 ...
- shell脚本 字串截取 正则表达式
字串处理 子串截取方法一:使用${}表达式格式:echo ${x:起始位置:长度}(起始位置编号从0开始,可省略) 方法二:使用expr substr格式:expr substr "$x&q ...
- Shell脚本的编写,sed的使用以及一些正则表达式
Shell脚本的简单编写以及sed的使用 标签(空格分隔): 博客文章 前一阵子为了批量修改Web审计规则,故编写了一个Shell脚本,顺便使用了下sed,顺便把正则表达式也重新学习一遍,感觉还是需要 ...
- shell脚本命令(sotr/unip/tr/cut/eval)与正则表达式
shell脚本命令(sotr/unip/tr/cut/eval)与正则表达式 1.sort命令 概述: Linux sort命令用于将文本文件内容加以排序. sort命令可针对文本文件的内容,以行为单 ...
- Linux shell 脚本攻略之正则表达式入门
摘自:<Linux shell 脚本攻略> 下面是类似的解释:
- 《Linux命令行与shell脚本编程大全 第3版》Linux命令行---14
以下为阅读<Linux命令行与shell脚本编程大全 第3版>的读书笔记,为了方便记录,特地与书的内容保持同步,特意做成一节一次随笔,特记录如下:
随机推荐
- 精尽Spring Boot源码分析 - 序言
该系列文章是笔者在学习 Spring Boot 过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring Boot 源码分析 GitHub 地址 进行阅读 Sprin ...
- docker4-docker网络,容器编排,集群部署
1,docker网络 1.1,docker0 有三个网络环境,那么docker是如何处理容器网络访问的? 1.2,测试 docker run -d -p 80:8080 --name tomcat01 ...
- Pytest学习笔记9-失败重跑
前言 在进行自动化测试的过程中,我们一定会有这样的需求:希望失败的用例可以自动重跑 在pytest中,提供了pytest-rerunfailures插件可以实现自动重跑的效果 插件安装 pip命令安装 ...
- 【spring源码系列】之【Bean的实例化】
人生需要探索的热情.坚持的勇气以及热爱生活热爱自己的力量. 1. Bean的实例化 上一篇讲述了bean的生命周期,其中第一步就涉及到了bean的实例化,本文重点分析bean实例化,先进入源码中的Ab ...
- 海康威视摄像头入侵+fofa(CVE-2017-7921)
海康威视摄像头入侵+fofa(CVE-2017-7921) By:Jesse 重保期间实在是太无聊,于是就找了个海康威视的摄像头日日玩,结果一玩就是一天呢哈哈哈. 1.漏洞编号 CVE-2017-79 ...
- CSS经典布局——圣杯布局与双飞翼布局
一.圣杯布局和双飞翼布局的目的 实现三栏布局,中间一栏最先加载和渲染 两侧内容固定,中间内容随着宽度自适应 一般用于PC网 二.圣杯布局的实现 技术要点: 设置最小宽度min-width 使用floa ...
- SpringBoot | 1.2 全注解下的Spring IoC
前言 在学习SpringBoot之前,有几个Spring的重要的基础概念需要提一下,SpringBoot对这些基础概念做进一步的封装,完成自动配置.首先就是Spring的控制反转IOC,由于Sprin ...
- MySql:Windows10安装mysql-8.0.18-winx64步骤
步骤: 1. 首先在安装的mysql目录下创建my.ini文件 (深坑)注意:my.ini必须保存为ANSI格式!!! 可以先创建一个my.txt的文件,然后另存为ANSI格式的文件! my.ini内 ...
- edraw max for mac 安装
1.下载网址:https://xclient.info/s/edraw-max.html#versions 2.安装断网安装,直接打开 .dmg文件安装 3.按照阅读文件中的第二步,将opt.cell ...
- C语言:fopen函数
在C语言中,操作文件之前必须先打开文件:所谓"打开文件",就是让程序和文件建立连接的过程.打开文件之后,程序可以得到文件的相关信息,例如大小.类型.权限.创建者.更新时间等.在后续 ...