# ### 正则表达式 => 命名分组
import re
strvar = "<p>今天天气不错</p>"

# 正常匹配
lst = re.findall(r"<(.*?)>(.*?)<(.*?)>",strvar)
print(lst)

# 反向引用 \1 代表的是把第一个括号匹配到的值,拿过来在引用一次
lst = re.findall(r"<(.*?)>(.*?)<(/\1)>",strvar)
print(lst)

# 2.命名分组
# 3) (?P<组名>正则表达式) 给这个组起一个名字
# 4) (?P=组名) 引用之前组的名字,把该组名匹配到的内容放到当前位置

lst = re.findall(r"<(?P<tag1>.*?)>(.*?)</(?P=tag1)>",strvar)
print(lst)

# 方法一
strvar = "a1b2cab"
obj = re.search(r"(?P<tag1>.*?)\d(?P<tag2>.*?)\d(.*?)(?P=tag1)(?P=tag2)",strvar)
print(obj)
res = obj.group()
print(res)
res = obj.groups()
print(res)

# 方法二
obj = re.search(r"(?P<tag1>.*?)\d(?P<tag2>.*?)\d(.*?)\1\2",strvar)
print(obj)
print(obj.group())
posted on 2021-03-30 18:56  rider_yang  阅读(703)  评论(0)    收藏  举报