Python re模块 | Python正则 函数介绍 flags修饰符全解析

2024-01-22 05:36

本文主要是介绍Python re模块 | Python正则 函数介绍 flags修饰符全解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1 re基本形式
  • 2 函数介绍
    • 2.1 re.compile
    • 2.2 re.match
    • 2.3 re.search
    • 2.4 re.findall
    • 2.5 re.finditer
    • 2.6. re.sub
    • 2.7 re.split
  • 3 flags修饰符

re 模块是 Python 标准库中的正则表达式模块,用于对字符串进行正则表达式匹配和操作。正则表达式是一种强大的文本模式匹配工具,允许你通过一种灵活的方式搜索、匹配和替换字符串。以下是 re 模块的一些主要功能和常用函数:

1 re基本形式

re.func(pattern,string,flags=0)

参数说明

pattern:模式,正则匹配规则,匹配规则可以看这篇博客

string: 要匹配的字符串

flags:修饰符

2 函数介绍

以下的r’xxx’ r开头的单引号扩住的是正则表达式

2.1 re.compile

re.compile(pattern, flags=0)

编译正则表达式模式,返回一个正则表达式对象。这个对象可以用于执行下面的各种正则操作。

import re
pattern = re.compile(r'\b\w+\b')  # 匹配单词

2.2 re.match

re.match(pattern, string, flags=0)

尝试从字符串的开头匹配正则表达式模式。如果匹配成功,返回第一个匹配对象;否则返回 None

match = re.match(r'hello', 'hello world')

或者可以通过现成的pattern.match(string)

2.3 re.search

re.search(pattern, string, flags=0)

在字符串中搜索正则表达式模式,返回一个匹配到的匹配对象。如果没有匹配到,返回 None

search_result = re.search(r'\d+', 'The price is $42')

这里注意re.match和re.search的区别

  • re.match只匹配字符串的开始。如果字符串开始不符合正则表达式,则匹配失败,函数返回None。
  • re.search匹配整个字符串,直到找到一个匹配。

如下面的例子

import reprint(re.match('abc', 'abcf'))  # 输出 <re.Match object; span=(0, 3), match='abc'>
print(re.match('abc', 'fabc'))  # 输出 Noneprint(re.search('abc', 'abcf'))  # 输出 <re.Match object; span=(0, 3), match='abc'>
print(re.search('abc', 'fabc'))  # 输出 <re.Match object; span=(1, 4), match='abc'>

2.4 re.findall

re.findall是Python的re模块中的一个函数,它可以找到字符串中所有匹配正则表达式的部分,并返回一个包含这些匹配结果的列表。

例如,考虑下面的字符串和正则表达式:

import retext = "apple banana apple banana apple"# 找到所有的"apple"print(re.findall('apple', text)) # 输出 ['apple', 'apple', 'apple']

在这个例子中,re.findall('apple', text)找到了字符串中所有的"apple",并返回了一个包含这些"apple"的列表。

2.5 re.finditer

re.finditer() 是 Python 中 re 模块提供的一个函数,用于在字符串中查找所有匹配正则表达式的非重叠子字符串。不同于 re.findall() 返回匹配的字符串列表,re.finditer() 返回一个迭代器,该迭代器产生每个匹配对象的 match 对象。迭代器可以用于for循环等,迭代具体知识,可以查看我的这篇博客Python | 超详细的可迭代对象(原理and代码)_python 可迭代对象-CSDN博客

以下是 re.finditer() 的基本用法:

import repattern = re.compile(r'\d+')text = 'There are 123 apples and 456 oranges.'matches = pattern.finditer(text)for match in matches:print(f"Match found: {match.group()} at position {match.start()}-{match.end()}")

在这个例子中,re.finditer() 查找字符串中的所有数字,输出它们的位置和值。

要注意的是,re.finditer() 返回的是一个迭代器

可以使用 for 循环来遍历所有的匹配。每次迭代都会得到一个匹配对象,

可以使用 group() 方法来获取匹配的字符串,使用 start()end() 方法获取匹配的起始和结束位置。

2.6. re.sub

re.sub(pattern, replacement, string, count=0, flags=0)

re.sub() 是 Python 中 re 模块提供的函数之一,用于在字符串中替换正则表达式匹配的文本。

举例如下

import retext = "The price of the product is $20. The discount is 10%."# 将价格替换为'XX'
result = re.sub(r'\$\d+', 'XX', text)print(result)
# 输出The price of the product is XX. The discount is 10%.

2.7 re.split

re.split(pattern, string, maxsplit=0, flags=0)

使用正则表达式模式拆分字符串,并返回拆分后的子字符串列表。

import retext = "Hello World, how are you today?"# 使用空格分割字符串
words = re.split(r'\s', text)print(words)
# 输出['Hello', 'World,', 'how', 'are', 'you', 'today?']

在这个例子中,re.split() 根据正则表达式模式 \s(匹配任意空白字符)分割字符串,得到一个包含单词的列表。输出结果为:

输出[‘Hello’, ‘World,’, ‘how’, ‘are’, ‘you’, ‘today?’]

还有比如

3 flags修饰符

再介绍flags修饰符,这些修饰符可以用来修改正则表达式的匹配行为。以下是一些常用的修饰符:

  1. re.IGNORECASE (或 re.I):

    • 不区分大小写

    • 示例:匹配所有形式的"hello",不区分大小写。不加的话只会匹配"hello"

      import repattern = re.compile(r'hello', re.IGNORECASE)
      result = pattern.match('Hello, World!')
      print(result.group())  # 输出: Hello
      
  2. re.MULTILINE (或 re.M):

    • 正常情况下,只从开头匹配,加上之后会进行多行模式,每一行开头都匹配一次

    • 示例:匹配每一行的开头

      import retext = """
      apple
      banana
      cherry"""# 默认情况下,^只匹配字符串的开始
      print(re.findall('^banana', text))  # 输出 []# 如果设置了re.MULTILINE,^也会匹配每一行的开始
      print(re.findall('^banana', text, re.MULTILINE))  # 输出 ['banana']
      
  3. re.DOTALL (或 re.S):

    • re.DOTALL是Python正则表达式的一个标志,它改变了.(点)的行为。在默认情况下,.匹配除了换行符(\n)之外的任何字符。但是如果设置了re.DOTALL.也会匹配换行符。

    • 示例:匹配包含换行符的多行文本。

      import retext = "apple\nbanana"# 默认情况下,.不匹配换行符
      print(re.findall('apple.banana', text))  # 输出 []# 如果设置了re.DOTALL,.也会匹配换行符
      print(re.findall('apple.banana', text, re.DOTALL))  # 输出 ['apple\nbanana']
      
  4. re.VERBOSE (或 re.X):

    • 允许你编写更易读的正则表达式。当设置了re.VERBOSE后,你可以在正则表达式中添加空格和注释,这些空格和注释不会影响正则表达式的匹配行为。

    • 示例:使用空格和注释的可读正则表达式。 正则表达式内加了注释不影响匹配

      import repattern = re.compile(r'''\d+   # 匹配数字[a-z]+  # 匹配小写字母''', re.VERBOSE)
      result = pattern.match('123abc')
      print(result.group())  # 输出: 123abc
      
  5. re.ASCII (或 re.A):

    • 匹配只包含ASCII字符的单词

    • 示例:如!就不会被匹配

      import repattern = re.compile(r'\w+', re.ASCII)
      result = pattern.match('Hello123!')
      print(result.group())  # 输出: Hello123
      

这些示例演示了如何使用不同的标志来修改正则表达式的匹配行为。

这篇关于Python re模块 | Python正则 函数介绍 flags修饰符全解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/631994

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss