正则表达式使用举例一(Python下)

目录

  • [1 问题描述](#1 问题描述)
  • [2 解决](#2 解决)
    • [2.1 问题1的解决](#2.1 问题1的解决)
    • [2.2 问题2的解决](#2.2 问题2的解决)

摘要:本文给出了一个在Python语言中利用re包进行正则表达式匹配计算的例子。详细讲述了所写的正则表达式的含义,还对搜索结果对象的span()函数进行运用举例,从而成功提取出原字符串中的三部分。

1 问题描述

有下面所述的字符串,

' 你好左,QTZ(Ap^max),右边'

'左边描述,QT2(xx1/xx2^ out^ on)QT2(xx2/xx2^out),右边描述'

'左边描述,%QT2(xx1/xx2 ^ out^ on)QT2(xx2/xx2^out),右边描述'

问题1:编写代码将上面三种情况的字符串中的"QTZ(Ap^max)"、"QT2(xx1/xx2 ^ out^ on)QT2(xx2/xx2^out)"、"%QT2(xx1/xx2 ^ out ^ on)QT2(xx2/xx2 ^out)"查询匹配出来?

问题2:写代码,将上面字符串分别分成三部分,第一部分是要匹配的字符串的左边部分子字符串,第二部分是问题1要匹配的字符串,第三部分是要匹配的字符串的右边部分子字符串。

2 解决

2.1 问题1的解决

在Python语言环境下,写如下的字符串表达式:

python 复制代码
r"%?QT\w\(.*\)"

上面字符串表达式的含义解释如下:

  1. r是Python语言中的机制,表示后面所跟的字符串保持原样,亦即Python中的转义字符机制不发生作用;
  2. %,表示匹配该字符;
  3. ?,表示其前面的字符%可以出现1次,也可以出现0次(不出现);
  4. QT,原样匹配;
  5. \w,是正则表达式中预先定义的字符类[1](#1),表示匹配一个字母字符或数字字符,等价于[a-zA-Z0-9];
  6. \(,表示匹配一个(,因为(在正则表达式中是元字符,启指令作用,所以要匹配字符(需要正则表达式中的转义字符\
  7. .,表示匹配任何一个字符;
  8. *,表示对前面出现的一个字符重复多次;
  9. \),与\(同义。

上面所写的正则表达式刚好能匹配小节1里面的三种情况的字符串中要匹配的子字符串,即:"QTZ(Ap^max)"、"QT2(xx1/xx2 ^ out^ on)QT2(xx2/xx2^out)"、"%QT2(xx1/xx2 ^ out ^ on)QT2(xx2/xx2 ^out)"。

在Python语言中,编写解决问题1的代码,并运行,如下:

python 复制代码
>>> import re
>>> s = ' 你好左,QTZ(Ap^max),右边'
>>> s2 = '左边描述,QT2(xx1/xx2^out^on)QT2(xx2/xx2^out),右边描述'
>>> s3 = '左边描述,%QT2(xx1/xx2^out^on)QT2(xx2/xx2^out),右边描述'
>>> pat = re.compile(r"%?QT\w\(.*\)")
>>> pat.search(s)
<re.Match object; span=(5, 16), match='QTZ(Ap^max)'>
>>> pat.search(s2)
<re.Match object; span=(5, 40), match='QT2(xx1/xx2^out^on)QT2(xx2/xx2^out)'>
>>> pat.search(s3)
<re.Match object; span=(5, 41), match='%QT2(xx1/xx2^out^on)QT2(xx2/xx2^out)'>
>>>

从上面代码的运行结果可以看出,Python中re的正则表达式匹配默认启用贪婪模式(greedy),因为能匹配出'QT2(xx1/xx2^out^on)QT2(xx2/xx2^out)'。如果是非贪婪模式的话,则能匹配出两个结果'QT2(xx1/xx2^out^on)''QT2(xx2/xx2^out)'

2.2 问题2的解决

以问题小节中描述的第三个字符串为例,从中提取出三部分代码如下:

python 复制代码
>>> s3 = '左边描述,%QT2(xx1/xx2^out^on)QT2(xx2/xx2^out),右边描述'
>>> pat = re.compile(r"%?QT\w\(.*\)")
>>> searchResult = pat.search(s3)
>>> m,n = searchResult.span()
>>> m
5
>>> n
41
>>> s3[0:m]
'左边描述,'
>>> s3[m:n]
'%QT2(xx1/xx2^out^on)QT2(xx2/xx2^out)'
>>> s3[n:]
',右边描述'
>>>

上述解决问题2的代码中,利用了搜索结果对象中的span()函数,该函数给出了匹配的字符串结果在原字符串中的起始索引,利用该起始索引,我们可以成功将原字符串的三部分提取出来。


  1. Félix López, Víctor Romero. Mastering Python Regular Expressions. Packt Publishing Ltd, 2014. P12-13. ↩︎
相关推荐
好家伙VCC14 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
前端玖耀里15 小时前
如何使用python的boto库和SES发送电子邮件?
python
serve the people15 小时前
python环境搭建 (十二) pydantic和pydantic-settings类型验证与解析
java·网络·python
小天源15 小时前
Error 1053 Error 1067 服务“启动后立即停止” Java / Python 程序无法后台运行 windows nssm注册器下载与报错处理
开发语言·windows·python·nssm·error 1053·error 1067
喵手16 小时前
Python爬虫实战:HTTP缓存系统深度实战 — ETag、Last-Modified与requests-cache完全指南(附SQLite持久化存储)!
爬虫·python·爬虫实战·http缓存·etag·零基础python爬虫教学·requests-cache
喵手16 小时前
Python爬虫实战:容器化与定时调度实战 - Docker + Cron + 日志轮转 + 失败重试完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·容器化·零基础python爬虫教学·csv导出·定时调度
2601_9491465316 小时前
Python语音通知接口接入教程:开发者快速集成AI语音API的脚本实现
人工智能·python·语音识别
寻梦csdn17 小时前
pycharm+miniconda兼容问题
ide·python·pycharm·conda
Java面试题总结17 小时前
基于 Java 的 PDF 文本水印实现方案(iText7 示例)
java·python·pdf
不懒不懒18 小时前
【决策树算法实战指南:从原理到Python实现】
python·决策树·id3·c4.5·catr