Linux基础之正则表达式

Linux基础之正则表达式正则表达式:又称规则表达式。(英语:RegularExpression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。正则表达式是对字符串(包括普通字符(例如,a到z之间的字母)和特殊字符(称为“元字符”))操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符…

大家好,又见面了,我是你们的朋友全栈君。

正则表达式:又称规则表达式(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。

正则表达式是对字符串(包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为“元字符”))操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。正则表达式是一种文本模式,该模式描述在搜索文本时要匹配的一个或多个字符串。

给定一个正则表达式和另一个字符串,我们可以达到如下的目的:

1. 给定的字符串是否符合正则表达式的过滤逻辑(称作“匹配”):

2. 可以通过正则表达式,从字符串中获取我们想要的特定部分。

我们可以使用 grep 命令来测试我们的正则表达式,grep命令使用正则表达式去尝试匹配指定文件的每一行,并将至少有一处匹配表达式的所有行显示出来。

grep 命令说明:

Linux基础之正则表达式

常用的选项OPTION:

-c 显示匹配到的行数之和
-o 仅显示匹配本身 
-v 显示非匹配,取反 
-i 不区分大小写
-E 支持扩展表达式 
-q 静默模式 
-n 显示匹配到的行的行号
-A 2 显示匹配到的行的后2行
-B 2 显示匹配到的行的前2行
-C 2 显示匹配到的行的前后2行
-V 显示版本信息

使用语法:

grep [OPTION]… PATTERN [FILE]…

grep “[匹配字符]匹配出现次数” /PATH/TO/SOMEFILE

字符匹配:

. 任意单个字符
[] 指定范围内的单个字符
[^] 指定范围外的的单个字符,取反
.* 任意长度的任意字符
[:alnum:] 所有的字母和数字      
[:alpha:] 所有的字母
[:blank:] 所有呈水平排列的空白字符
[:cntrl:] 所有的控制字符
[:digit:] 所有的数字
[:graph:] 所有的可打印字符,不包括空格
[:lower:] 所有的小写字母     
[:print:] 所有的可打印字符,包括空格
[:punct:] 所有的标点字符 
[:space:] 所有呈水平或垂直排列的空白字符
[:upper:] 所有的大写字母    
[:xdigit:] 所有的十六进制数
[=字符=] 所有和指定字符相等的字符

匹配次数 :

* 其前面的字符出现任意次,0次或1次,或者多次
\? 其前面的字符出现0次或1次
\+ 其前面的字符出现1次或多次,至少出现1次
\{m\} 指定字符出现次数
\{m,n\} 至少出现m次,至多出现n次,范围取次 
\{0,n\} 出现最多n次          
\{m,\} 出现最少m次

位置锚定:

^ 行首锚定,用于模式的最左侧 
$ 行尾锚定,用于模式的最右侧 
^……$ 整行, ^$ 空白行,^[[:space:]]*$  空行或者有空白字符的行
\< 或 \b  词首锚定
\> 或 \b  词尾锚定
\<……\>  精确锚定单词

分组及引用:

\{xy\}*ab     表示多个字符出现0,1或多次。 \ 在这里作为转义符使用
\(abcd\){1,3}    表示包含abcd字符串最少出现1次,最多出现3次
\(1..2\).*        是指引用从左侧起第一个()之间的字符
\(1..2\).* \(3..4\)     是指引用从左侧起第二个()之间的字符
\(1..2\).* \(3..4\).*\(5..6\)    是指引用从左侧起第三个()之间的字符

 

使用实例:

查看显示 /etc/fstab 文件以 # 注释开头的行:

Linux基础之正则表达式

这里也可以不加【】:

Linux基础之正则表达式

-v 取反,即显示不以#注释的行,-o 选项为只显示匹配到的字符串:

Linux基础之正则表达式

显示 /etc/fstab 文件非注释的行,锚定行首为 # 注释的行,取反:

Linux基础之正则表达式

显示 /etc/fstab 文件以#号开头,后面跟一个空格,后面为任意长度任意字符的行, -c 选项可以统计匹配到的行数:

Linux基础之正则表达式

在 /tmp/fstab 文件中加入多个空白行,以#号开头,后面仅跟一个空格,且不以空白符结尾的行:

Linux基础之正则表达式

显示 /tmp/sshd_config 文件中不以#注释、空白行以及有空白字符的行:

Linux基础之正则表达式

显示 /etc/passwd 文件中用户名和用户SHELL为一样的行:

Linux基础之正则表达式

显示 /tmp 目录下,以非字母开头,后面跟一个字母,后面为任意长度任意字符的文件或者目录:

Linux基础之正则表达式

显示 /tmp 目录下以非字母开头,后面仅跟一个字母,然后以非字母结尾的文件和目录:

Linux基础之正则表达式

显示 /etc 目录下以p开头不以数字结尾的所有文件和目录:

Linux基础之正则表达式

显示 ip a 或者 ifconfig 命令中的IP地址,-E 选项为支持扩展正则表达式:

Linux基础之正则表达式

-l 选项可以列出包含字符串的文件列表:

Linux基础之正则表达式

-w 精确锚定字符串,相当于\<…|> :

Linux基础之正则表达式

egrep 的使用方法跟 grep 基本一致,不需要转义符 \ 看起来更简洁:

Linux基础之正则表达式

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/158715.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • mysql length函数无法对字段值为null的筛选

    mysql length函数无法对字段值为null的筛选 mysql中length(articletype)&lt;5不包含articletype的值为null

  • matlab之BM3D

    matlab之BM3D1.matlab代码2.

  • 使用idea创建springboot项目_idea创建普通java项目

    使用idea创建springboot项目_idea创建普通java项目约定大于配置;帮我们自动配置了我们需要配置的内容;并且帮我们自动下载了需要下载的jar包以及运行环境;优点:方便,作为初学者来说直接使用就可以了;缺点:出现问题,我们作为初学者很难去定位解决

  • java 随机数算法_Java随机数算法原理与实现方法实例详解

    java 随机数算法_Java随机数算法原理与实现方法实例详解本文实例讲述了Java随机数算法。分享给大家供大家参考,具体如下:软件实现的算法都是伪随机算法,随机种子一般是系统时间在数论中,线性同余方程是最基本的同余方程,“线性”表示方程的未知数次数是一次,即形如:ax≡b(modn)的方程。此方程有解当且仅当b能够被a与n的最大公约数整除(记作gcd(a,n)|b)。这时,如果x0是方程的一个解,那么所有的解可以表示为:{x0+k…

  • 自动编码器(Autoencoder)

    自动编码器(Autoencoder)autoencoder是一种无监督的学习算法。在深度学习中,autoencoder用于在训练阶段开始前,确定权重矩阵WW的初始值。神经网络中的权重矩阵WW可看作是对输入的数据进行特征转换,即先将数据编码为另一种形式,然后在此基础上进行一系列学习。然而,在对权重初始化时,我们并不知道初始的权重值在训练时会起到怎样的作用,也不知道在训练过程中权重会怎样的变化。因此一种较好的思

  • 用new创建数组

    用new创建数组用new创建数组用new创建数组的优势由于new创建的对象是在运行时确立的,所以有着具体情况具体分析的优点,那么什么叫做具体情况具体分析呢?我觉得c++primerplus的一个例子十分贴切——比如你在度假,已经做好每天的参观计划,可突然有一天天气不好或你心情不好,此时你就不想参观了,如果此时是在编译状态,系统是不允许的,你必须按照计划去参观,但运行时状态,系统是允许的,此时你就可以呆在酒店尽情的玩耍了。用new创建数组也有此优点,即数组长度可以根据情况而定。比如说创建10个元素的数组,可以如下代

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号