正则表达式

文章目录

一、正则表达式

  • 正则表达式就是一行字符串,用来描述一定的规则。

  • 正则表达式(Regular Expression),通常采用这两个单词的首字母合在一起,把正则表达式相关的变量名定义为 regexp(单数)或 regexps(复数)。

  • 在 Java 的 String 类中,也会有几个相关的替换方法,它也是支持正则表达式的,它的参数命名也为 regex 。

  • 正则表达式在线练习网站: 正则表达式在线练习网站

1.1 正则的组成结构

  • 正则表达式通常由一些字符,以及一些元字符组成。
  • 普通字符:就是本身作为一个字符时,它不具有其它含义,像我们常用的大小写字母和数字。
  • 元字符:就是除了本身作为一个字符外,它还可以表达其它含义。

二、基础语法表格

  • 首先是最基础的匹配规则
single char(单字符) quantifiers(数量) position(位置)
\d 匹配数字 * 0个或者多个 ^一行的开头
\w 匹配word(数字、字母) + 1个或者更多,至少一个 $一行的结尾
\W 匹配非word(数字、字母) ? 0个或1个,一个Optional \b 单词"结界"(word bounds)
\s 匹配white space (包括空格、tab等) {min,max}出现次数在一个范围内
\S 匹配非white space(包括空格、tab等) {n}匹配出现n次的
. 匹配任何,任何的字符

三、元字符

  • 正则表达式主要依赖于元字符。元字符不代表它们本身的字面意思,它们都是有特殊的含义。一些元字符写在方括号( [ ] )中的时候有一些特殊的意思。
元字符 描述
. 点匹配任意单个字符,除了换行符。
[ ] 字符种类。匹配方括号( [ ] )内的任意字符。
[^ ] 否定的字符种类。匹配除了方括号里的任意字符。
* 匹配>=0个重复的在 * 号之前的字符。
+ 匹配>=1个重复的 + 号前的字符。
标记 ? 之前的字符为可选。
{n,m} 匹配 num 个大括号之前的字符或字符集(n <= num <= m)。
(xyz) 字符集,匹配符号前或后的字符。
| 或运算符,匹配符号前或后的字符。
\ 转义字符,用于匹配一些保留的字符 ` [ ] ( ) . * + ? ^ $
^ 从开始行开始匹配。
$ 从末端开始匹配。

3.1 点运算符 -- > .

  • " . " 是元字符中最简单的例子。" . " 匹配任意单个字符,但不匹配换行符。例:表达式 [. . . o] 匹配3个(几个点就几位)任意字符后面跟着是 [ o ] 的字符串。
相关推荐
中國移动丶移不动16 小时前
Java字符编码与正则表达式深度解析
java·开发语言·正则表达式
功德+n2 天前
深入理解正则表达式及基本使用教程
正则表达式
不是二师兄的八戒2 天前
深入解析-正则表达式
正则表达式
运维搬运工2 天前
扩展正则表达式
正则表达式
我叫czc2 天前
【Python高级374】正则表达式
python·mysql·正则表达式
轩轩9902182 天前
正则表达式在JSON里报错
前端·正则表达式·前端框架
背太阳的牧羊人3 天前
在正则表达式中,\1 是用来引用第一个捕获组的内容的。捕获组是用括号 () 包裹的部分
正则表达式
背太阳的牧羊人3 天前
df.replace(regex={‘b‘: {r‘\s*\.\s*‘: np.nan}})
python·正则表达式
背太阳的牧羊人3 天前
df.replace({‘b‘: r‘\s*(\.)\s*‘}, {‘b‘: r‘\1ty‘}, regex=True)
开发语言·正则表达式·pandas
kkwlgs3 天前
正则表达式
java·正则表达式