# ### 正则表达式 => 匹配分组
import re
print(re.findall('.*?_good','wusir_good alex_good secret男_good'))
# 把想要匹配的内容,用小圆括号包起来,表达分组
print(re.findall('(.*?)_good','wusir_good alex_good secret男_good'))
# ?: 取消括号优先显示的功能
print(re.findall('(?:.*?)_good','wusir_good alex_good secret男_good'))

# | 代表或 , a|b 匹配字符a 或者 匹配字符b . 把字符串长的写在前面,字符串短的写在后面
# abc 或者 abcd
strvar = "abcpiopipoabcd234"
lst = re.findall("abc|abcd",strvar)
print(lst)

# 改写
lst = re.findall("abcd|abc",strvar)
print(lst)

"""
\ 可以把有意义的字符变得无意义,还可以把无意义的字符变得有意义,用来转义字符
\n : 换行
\. : 单纯的匹配一个点
"""
"""
5.6
\d\.\d

39.56
\d+\.\d+
"""
# 匹配小数
strvar = "3.56 89.. .898234 8,67 39.56 34"
lst = re.findall("\d+\.\d+",strvar)
print(lst)

# 匹配小数和整数
lst = re.findall(r"\d+\.\d+|\d+",strvar)
print(lst)

# 使用分组合并正则 匹配小数和整数
lst = re.findall(r"\d+(?:\.\d+)?",strvar)
print(lst)

# 匹配135或171的手机号
lst = re.findall(r"(?:135|171)\d{8}","13566668888 17112345678 185996964545")
print(lst)

lst = re.findall(r"^(?:135|171)\d{8}$","13566668888")
print(lst)

# 匹配www.baidu.com 或者 www.oldboy.com
strvar = "www.oldboy.com www.baidu.com"
lst = re.findall(r"(?:www)\.(?:baidu|oldboy)\.(?:com)",strvar)
print(lst)

# search
"""
findall 匹配所有内容,缺陷:不能把匹配到的内容和分组里面的内容同时显示出来,返回的是列表
search 匹配到一个内容就直接返回,优点:可以把分组的内容,和实际匹配到的内容分开,同时显示,返回的是对象obj

obj.group() 获取匹配到的内容
obj.groups() 获取分组里面的内容
"""
strvar = "www.oldboy.com www.baidu.com"
obj = re.search(r"(www)\.(baidu|oldboy)\.(com)",strvar)
print(obj)
# 获取匹配到的内容
res = obj.group()
print(res)
# 获取分组里面的内容 (推荐)
res = obj.groups()
print(res)

# 获取分组里第一个元素
res = obj.group(1)
print(res)
# 获取分组里第二个元素
res = obj.group(2)
print(res)
# 获取分组里第三个元素
res = obj.group(3)
print(res)

# "5*6-7/3" 匹配 5*6 或者 7/3
strvar = "5*6-7/3"
obj = re.search(r"\d+[*/]\d+",strvar)
res = obj.group()
print(res)

30
""
replace("5*6","30") "5*6-7/3"

 

posted on 2021-03-30 18:55  rider_yang  阅读(303)  评论(0)    收藏  举报