Python正则表达式

 

正则表达式

基础知识

  • 模块导入
    import re

  • 获取指定字符串中与正则表达式匹配的对象,并打印

result = re.match(正则表达式,字符串) 
result.group() 

单字符匹配

字符功能
.匹配任意1个字符(除了\n)
[]匹配[]中列举的字符
\d匹配数字,即0-9
\D匹配非数字,即不是数字
\s匹配空白字,即空格、tab键、\n
\S匹配非空白
\w匹配单字符,即a-z、A-Z、0-9、_(包括汉字等其它语言)
\W匹配非单字符

多个字符匹配

字符功能
*匹配前一个字符出现0次或者无限次,即可有可无
+匹配前一个字符出现1次或者无限次,即至少1次
?匹配前一个字符出现1次或者0次,即要么有1次,要么没有
{m}匹配前一个字符出现m次
{m,n}匹配前一个字符出现m到n次

注意
如果需要

.*匹配\n,则

html_content = """
fsdfa
dfafff
dfaf
"""
re.match(r".*", html_content,  re.S).group()

匹配开头结尾

字符功能
^匹配字符串开头
$匹配字符串结尾

匹配分組

字符功能
|匹配左右任意一个表达式
(ab)将括号中字符作为一个分组
\num引用分组num匹配到的字符串
(?P<name>)分组起别名
(?P=name)引用别名为name分组匹配到的字符串

示例

示例1
判断变量名是否符合python变量命名规范

示例2
匹配出163的邮箱地址,且@符号之前有4到20位的英文字母、数字或下划线组成

re模块的高级用法

search

返回第一个与之匹配部分的对象

ret = re.search(r"\d+", "观看数: 99999")
ret.group()

match

从头开始匹配,返回与之匹配部分的对象,与

search的区别:

  • search是全文搜索直到搜索到第一与之匹配的
  • match则是从头开始匹配

findall

返回所有匹配的字符的列表

re.findall(r"\d+", "python = 999, c = 333, c++ = 123")

返回['999', '333', '123']

sub

替换匹配的内容(多处),然后重新返回字符串

re.sub(r"\d+", '998', "python 培训费 = 1000 )

返回:

python 培训费 = 998
如果中间(替换内容)是一个函数,那么匹配出来的对象会被当做函数的参数传递给函数,然后再用函数返回的结果的替换匹配的内容。

def add(temp):
    str_num =  temp.group()
    num = int(str_num) + 1
    return str(num)
    
ret = re.sub(r"\d+", add, "python = 1000")
print(ret)

返回:python = 1001

split

根据匹配的内容切割字符串,返回一个列表

re.split(r":|,", "Name: Sam, 男, 帅")

返回['Name', 'Sam', '男', '帅']

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python正则表达式是一种强大的字符串处理工具,它可以用于在文本中查找、替换和提取特定模式的字符串。在Python中使用正则表达式,需要先导入`re`模块。 下面是一个简单的示例代码,演示了如何使用正则表达式在字符串中匹配特定的模式: ```python import re # 定义一个待匹配的字符串 string = "Hello, my email address is example@example.com" # 定义一个正则表达式模式,用于匹配邮箱地址 pattern = r'\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}\b' # 使用re模块的findall()方法进行匹配 matches = re.findall(pattern, string) # 输出匹配的结果 print(matches) ``` 运行以上代码,输出结果会是`['example@example.com']`,即匹配到了字符串中的邮箱地址。 在正则表达式中,可以使用一些特殊字符和元字符来构建匹配模式。例如,`r'\b'`表示单词边界,`[A-Za-z0-9._%+-]`表示匹配字母、数字、点、下划线、百分号、加号和减号等字符。 除了匹配字符,还可以使用一些特殊的元字符来表示数量和位置。例如,`+`表示前面的字符出现一次或多次,`*`表示前面的字符出现零次或多次,`{2,}`表示前面的字符出现至少两次。 以上只是简单介绍了Python正则表达式的基本用法,实际上正则表达式还有很多高级用法和特性。你可以参考Python官方文档中关于`re`模块的详细说明来深入学习和理解正则表达式的使用方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值