import re
#验证用户名 和 qq 号
username = input('请输入用户名')
qq = input('请输入qq号')
m1 = re.match(r'^[0-9a-zA-Z]{6,20}$', username)
m2 = re.fullmatch(r'[1-9]\d{4,11}', qq)
pattern = re.compile(r'(?<=\D)1[34578]\d{9}(?=\D)')
sentence = '''重要的事情说8130123456789遍,我的手机号是13512346789这个靓号,
不是15600998765,也是110或119,王大锤的手机号才是15600998765。'''
# 方法一:查找所有匹配并保存到一个列表中
tels_list = re.findall(pattern, sentence)
for tel in tels_list:
print(tel)
print('--------华丽的分隔线--------')
# 方法二:通过迭代器取出匹配对象并获得匹配的内容
for temp in pattern.finditer(sentence):
print(temp.group())
print('--------华丽的分隔线--------')
# 方法三:通过search函数指定搜索位置找出所有匹配
m = pattern.search(sentence)
while m:
print(m.group())
m = pattern.search(sentence, m.end())
#替换字符串中的不良内容
sentence = 'Oh, shit! 你是傻逼吗? Fuck you.'
purified = re.sub('fuck|shit|[傻煞傻][比笔逼叉缺吊碉雕]',
'*', sentence, flags=re.IGNORECASE)
print(purified)
#拆分长字符串
poem = '床前明月光,疑是地上霜。举头望明月,低头思故乡。'
sentence_list = re.split(r'[,。]', poem)
for sentence in sentence_list:
print(sentence, end='\t')
Python 正则表达式
最新推荐文章于 2024-05-08 15:42:14 发布