python正则表达式匹配中文字符后面手机号码问题

在一个txt文档中,需要用正则表达式把身份证号码和手机号码提取出来。结果是:部分手机号码提取出来,紧跟在中文后面的手机号码无法提取。

python
import codecs
# -*- coding: UTF-8 -*-
import os
import re
       
def txtreg(filename):
    fr = codecs.open(filename,'r','utf-8')
    for line in fr:
        flag = 0
        line = line.strip()
        line = line.split()
        for j in range(len(line)):
            result_id = re.match(id_pattern,line[j].encode('utf-8').decode('utf-8','ignore'))
            result_ph = re.match(phone_pattern,line[j].encode('utf-8').decode('utf-8','ignore'))
            if result_id:
                flag = 1
                print(result_id.group(),end='   ')
            if result_ph:
                flag = 1
                print(result_ph.group(),end='   ')
        if flag:
            print()
#主程序
if __name__=='__main__':
    logfilename = r"x:/jz/log.txt"
    f = open(logfilename,'w')
    phone_pattern = re.compile(u'^1[3-9]\d{9}(?!\d)',re.I)
    id_pattern = re.compile(u'\d{6}[1-2]\d{10}[X\d](?!d)',re.I)
    txtreg('x:/jz/test.txt')
    f.close()

部分手机号码提取出来,紧跟在中文后面的手机号码和身份证号码无法匹配。

尝试的思路:包括在正则表达式前+r或者u,把要匹配的字符串编码和解码encode('utf-8').decode('utf-8','ignore')

我想要把手机号码和身份证号码都提取出来。

img

你这里使用了^字符,这个表示从字符开头开始匹配,所以开头不是1[3-9]的都匹配不上

phone_pattern = re.compile(u'(?<!\d)[^1][3-9]\d{9}(?!\d)',re.I)
我采用了负向后行、负向先行,仍然未能匹配具有中文字符或者中文符号的手机号码或者身份证号码。我估计是编码问题,请大牛人在测试的时候,中文后面紧跟身份证号码,和手机号码,包括中文符号后面紧跟身份证和手机号码。