python正則中最短匹配實現(xiàn)代碼
下面從一個例子入手:
利用正則表達式解析下面的XML/HTML標簽:
<composer>Wolfgang Amadeus Mozart</composer> <author>Samuel Beckett</author> <city>London</city>
希望自動格式化重寫為:
composer: Wolfgang Amadeus Mozart
author: Samuel Beckett
city: London
一個代碼是這樣的形式:
#coding:utf-8
import re
s="""<composer>WolfgangAmadeus Mozart</composer>
<author>SamuelBeckett</author>
<city>London</city>"""
pattern1=re.compile("<\w+>") #匹配<>中任意的字符
pattern2=re.compile(">.+</") #匹配><中任意的字符
listNames=pattern1.findall(s) #獲取所有滿足正則表達式pattern1的字符串的列表
listContents=pattern2.findall(s) #獲取所有滿足正則表達式pattern2的字符串的列表
#由于xml是規(guī)范的,所以是一一對應(yīng)(對于錯誤輸入,暫時不考慮)
for i in range(len(listNames)):
#輸出的時候利用切片丟棄多余的符號,如:<>/
print(listNames[i][1:len(listNames[i])-1],":",
listContents[i][1:len(listContents[i])-2])
這個代碼運行后結(jié)果是可以的。
下面我們修改下s的格式:
#coding:utf-8
import re
s="<composer>Wolfgang Amadeus Mozart</composer> <author>Samuel Beckett</author> <city>London</city>"
pattern1=re.compile("<\w+>") #匹配<>中任意的字符
# 此模式為非貪婪模式,所以s不是多行也可以匹配
pattern2=re.compile(">.+</") #匹配><中任意的字符,問號必須加,"?"是非貪婪匹配
listNames=pattern1.findall(s) #獲取所有滿足正則表達式pattern1的字符串的列表
listContents=pattern2.findall(s) #獲取所有滿足正則表達式pattern2的字符串的列表
#由于xml是規(guī)范的,所以是一一對應(yīng)(對于錯誤輸入,暫時不考慮)
for i in range(len(listNames)):
#輸出的時候利用切片丟棄多余的符號,如:<>/
print(listNames[i][1:len(listNames[i])-1],":",
listContents[i][1:len(listContents[i])-2])
得到的答案如下所示:

我們打印一下匹配到的兩個結(jié)果看一下,修改代碼如下:
#coding:utf-8
import re
s="<composer>Wolfgang Amadeus Mozart</composer> <author>Samuel Beckett</author> <city>London</city>"
pattern1=re.compile("<\w+>") #匹配<>中任意的字符
# 此模式為非貪婪模式,所以s不是多行也可以匹配
pattern2=re.compile(">.+</") #匹配><中任意的字符,問號必須加,"?"是非貪婪匹配
listNames=pattern1.findall(s) #獲取所有滿足正則表達式pattern1的字符串的列表
listContents=pattern2.findall(s) #獲取所有滿足正則表達式pattern2的字符串的列表
print(listNames)
print(listContents)
#由于xml是規(guī)范的,所以是一一對應(yīng)(對于錯誤輸入,暫時不考慮)
for i in range(len(listNames)):
#輸出的時候利用切片丟棄多余的符號,如:<>/
print(listNames[i][1:len(listNames[i])-1],":",
listContents[i][1:len(listContents[i])-2])
顯示結(jié)果如下:

從第一個箭頭顯示可以看出,這個處理是對的,那么看第二個箭頭,這個匹配的結(jié)果顯然是不對的了,那么是什么原因呢?
這是因為在正則中,‘*'、‘+'、‘?'這些是貪婪匹配,如用 a*,操作結(jié)果是盡可能多地匹配模式。所以當你試著匹配一對對稱的定界符,如 HTML 標志中的尖括號。匹配單個 HTML 標志的模式不能正常工作,因為 .* 的本質(zhì)是“貪婪”的 。在這種情況下,解決方案是使用不貪婪的限定符 *?、+?、?? 或 {m,n}?,盡可能匹配小的文本。
那么代碼可以修改如下:
#coding:utf-8
import re
s="<composer>Wolfgang Amadeus Mozart</composer> <author>Samuel Beckett</author> <city>London</city>"
pattern1=re.compile("<\w+?>") #匹配<>中任意的字符
# 此模式為非貪婪模式,所以s不是多行也可以匹配
pattern2=re.compile(">.+?</") #匹配><中任意的字符,問號必須加,"?"是非貪婪匹配
listNames=pattern1.findall(s) #獲取所有滿足正則表達式pattern1的字符串的列表
listContents=pattern2.findall(s) #獲取所有滿足正則表達式pattern2的字符串的列表
#由于xml是規(guī)范的,所以是一一對應(yīng)(對于錯誤輸入,暫時不考慮)
for i in range(len(listNames)):
#輸出的時候利用切片丟棄多余的符號,如:<>/
print(listNames[i][1:len(listNames[i])-1],":",
listContents[i][1:len(listContents[i])-2])
最后,用分組對代碼的正則進行優(yōu)化一下,如下:
#coding:utf-8
import re
s="<composer>Wolfgang Amadeus Mozart</composer><author>Samuel Beckett</author><city>London</city>"
pattern1=re.compile("<(\w+?)>") #匹配<>中任意的字符
# 此模式為非貪婪模式,所以s不是多行也可以匹配
pattern2=re.compile("<\w+?>(.+?)</\w+?>") #匹配<a>...</a>中任意的字符,問號必須加,"?"是非貪婪匹配
listNames=pattern1.findall(s) #獲取所有滿足正則表達式pattern1的字符串的列表
listContents=pattern2.findall(s) #獲取所有滿足正則表達式pattern2的字符串的列表
#由于xml是規(guī)范的,所以是一一對應(yīng)(對于錯誤輸入,暫時不考慮)
for i in range(len(listNames)):
print(listNames[i],":",
listContents[i])
這篇文章就介紹到這,大家可以多參考腳本之家以前發(fā)布的關(guān)于python 正則表達式的相關(guān)內(nèi)容。
相關(guān)文章
Tensorflow深度學(xué)習(xí)使用CNN分類英文文本
這篇文章主要為大家介紹了Tensorflow深度學(xué)習(xí)CNN實現(xiàn)英文文本分類示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2021-11-11
利用Anaconda完美解決Python 2與python 3的共存問題
Anaconda 是 Python 的一個發(fā)行版,如果把 Python 比作 Linux,那么 Anancoda 就是 CentOS 或者 Ubuntu,下面這篇文章主要給大家介紹了利用Anaconda完美解決Python 2與python 3共存問題的相關(guān)資料,文中介紹的非常詳細,需要的朋友可以參考借鑒。2017-05-05
Python解決“ImportError:?Couldn‘t?import?Django”問題全攻略
本文主要介紹了Python解決“ImportError:?Couldn‘t?import?Django”問題全攻略,具有一定的參考價值,感興趣的可以了解一下2025-03-03
Python中用pycurl監(jiān)控http響應(yīng)時間腳本分享
這篇文章主要介紹了Python中用pycurl監(jiān)控http響應(yīng)時間腳本分享,本文腳本實現(xiàn)監(jiān)控http相應(yīng)碼,響應(yīng)大小,建立連接時間,準備傳輸時間,傳輸?shù)谝粋€字節(jié)時間,完成時間,需要的朋友可以參考下2015-02-02
Python實現(xiàn)在數(shù)字中添加千位分隔符的方法小結(jié)
在數(shù)據(jù)處理和數(shù)據(jù)可視化中,經(jīng)常需要對大數(shù)值進行格式化,其中一種常見的需求是在數(shù)字中添加千位分隔符,本文為大家整理了三種常見方法,希望對大家有所幫助2024-01-01

