【python正则表达式匹配获取文本中的11位手机号码】
- 文前白话
- 代码实现
- 效果
- 正则知识补充
文前白话
根据需要,匹配一段没有固定格式的文本,识别其中的11位数字作为手机号,如果11位数字后还有数字,则不认为该11位数字是手机号,从文本中匹配出正确的手机号
如文件: info.txt
“匹配一段没有固定格式的文本,识别其中的11位数字作为手机号,如果11位数字后还有数字,则不认为该11位数字是手机号,从文本中匹配出正确的手机号物流单号:SF1311111111111开始配送:派送员-测试测试 电话1:12230182055,电话2:17755667788”
代码实现
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2021/09/23
# @Author : Wupke
# Purpose: 正则表达式匹配获取文本中的11位手机号码import re
import osf = open('info.txt','r',encoding='UTF-8')
# # 建立变量str ,赋值为读取到的文件内容,然后关闭打开的文件
str = f.read()
f.close()
# 自定义正则表达式,筛选符合的手机号
# patter = r"[\D]+(1\d{10})+(?!\d)"
# patter1 = "(1{1}\d{10})(?!\d)"
# patter2 = "SF\d+"
patter="(?<!\d)(1\d{10})(?!\d)" # 用 `?<!` 零宽断言res_phone=re.compile(patter).findall(str)
print("phone_list",res_phone)# 将筛选的结果写入文件存储
with open('getphonelist.txt','a') as phonelistfile:print('%s' %'reslt list is : ','%s' %res_phone,file=phonelistfile)
效果
正则知识补充
https://www.changchenghao.cn/n/660768.html
https://www.cnblogs.com/sen-c7/p/9921601.html
https://www.cnblogs.com/ww01/p/9805254.html
https://www.runoob.com/python/python-reg-expressions.html