Rumah > Soal Jawab > teks badan
Saya ingin menggunakan ungkapan biasa untuk mengekstrak maklumat berikut. Bagaimana saya harus menulisnya?
123 男 北京 张三
343 女 河北 石家庄 李四
2343 男 山东 王五
提取 男 张三
女 李四
男 王五
PHP中文网2017-06-14 10:55:06
Malah, untuk bahasa Cina, terutamanya bahasa Cina dalam format ini, saya tidak mengesyorkan menggunakan ungkapan biasa, walaupun ia boleh dicapai dengan susah payah:
# coding: utf8
import re
filename = '2.txt'
patern = re.compile(r'^\d+ (\S+).*?(\S+)')
with open(filename) as f:
for i in f:
result = patern.findall(i[:-1])
if result and len(result[0]) == 2:
print result[0][0], result[0][1]
# 输出:
男 北京
女 河北
男 山东
Anda juga boleh menggunakan split
的方法(建议
):
# coding: utf8
filename = '2.txt'
with open(filename) as f:
for i in f:
result = i.split()
print result[1], result[-1]
# 输出:
男 北京
女 河北
男 山东