這篇文章主要介紹了Python使用正規表示式過濾或替換HTML標籤的方法,簡單介紹了Python正則相關語法並結合具體實例形式分析了Python基於正則表達式的HTML標籤過濾與替換相關操作技巧,需要的朋友可以參考下
本文實例講述了Python使用正規表示式過濾或替換HTML標籤的方法。分享給大家供大家參考,具體如下:
python正規表示式關鍵內容:
python正規表示式轉義符:
. 匹配除換行符以外的任意字元
\w 匹配字母或數字或底線或漢字
\s 匹配任意的空格符
\d 匹配數字
\b 匹配單字的開始或結束
^ 匹配字串的開始
$ 匹配字串的結束
\W 匹配任意不是字母,數字,下劃線,漢字的字元
\S 符合任意不是空格符的字元
\D 符合任意非數字的字元
\B 符合不是單字開頭或結束的位置
[^x] 符合除了x以外的任意字元
[^aeiou] 符合除了aeiou這幾個字母以外的任意字元
常用的python正規表示式限定符代碼/語法說明:
##*重複零次或更多次
+重複一次或更多次
?重複零次或一次
{n}重複n次
{n,}重複n次或更多次
{n,m}重複n到m次
關於python正規表示式命名組:
命名組:(?P
這篇文章裡面也提到了界定( 問號開頭,前向則有個'<'號,非則有個'!' 號):
前向界定(?<=…)
後向界定(?=…)
前向非界定(?後向非界定(?!.....)
#Python透過正規表示式移除(過濾)HTML標籤範例程式碼
#-*- coding:utf-8 -*- import re ##过滤HTML中的标签 # 将HTML中标签等信息去掉 # @param htmlstr HTML字符串. def filter_tags(htmlstr): # 先过滤CDATA re_cdata = re.compile("//<! CDATA\[[>]∗// \]>", re.I) #匹配CDATA re_script = re.compile('<\s*script[^>]*>[^<]*<\s*/\s*script\s*>', re.I) # Script re_style = re.compile('<\s*style[^>]*>[^<]*<\s*/\s*style\s*>', re.I) # style re_br = re.compile('<br\s*?/?>') # 处理换行 re_h = re.compile('</?\w+[^>]*>') # HTML标签 re_comment = re.compile('<!--[^>]*-->') # HTML注释 s = re_cdata.sub('', htmlstr) # 去掉CDATA s = re_script.sub('', s) # 去掉SCRIPT s = re_style.sub('', s) # 去掉style s = re_br.sub('\n', s) # 将br转换为换行 s = re_h.sub('', s) # 去掉HTML 标签 s = re_comment.sub('', s) # 去掉HTML注释 # 去掉多余的空行 blank_line = re.compile('\n+') s = blank_line.sub('\n', s) s = replaceCharEntity(s) # 替换实体 return s ##替换常用HTML字符实体. # 使用正常的字符替换HTML中特殊的字符实体. # 你可以添加新的实体字符到CHAR_ENTITIES中,处理更多HTML字符实体. # @param htmlstr HTML字符串. def replaceCharEntity(htmlstr): CHAR_ENTITIES = {'nbsp': ' ', '160': ' ', 'lt': '<', '60': '<', 'gt': '>', '62': '>', 'amp': '&', '38': '&', 'quot': '"''"', '34': '"', } re_charEntity = re.compile(r'?(?P<name>\w+);') sz = re_charEntity.search(htmlstr) while sz: entity = sz.group() # entity全称,如> key = sz.group('name') # 去除&;后entity,如>为gt try: htmlstr = re_charEntity.sub(CHAR_ENTITIES[key], htmlstr, 1) sz = re_charEntity.search(htmlstr) except KeyError: # 以空串代替 htmlstr = re_charEntity.sub('', htmlstr, 1) sz = re_charEntity.search(htmlstr) return htmlstr def repalce(s, re_exp, repl_string): return re_exp.sub(repl_string, s) if __name__ == '__main__': s = file('test.html').read() news = filter_tags(s) print news
以上是Python使用正規表示式過濾或取代HTML標籤方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!