Python使用正则表达式过滤或替换HTML标签的方法详解


Posted in Python onSeptember 25, 2017

本文实例讲述了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<name>.....)
这篇文章里面还提到了界定( 问号开头,前向则有个'<'号,非则有个'!' 号 ):
前向界定 (?<=…)
后向界定 (?=…)
前向非界定 (?<!....)
后向非界定 (?!.....)

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 相关文章推荐
Python文件操作类操作实例详解
Jul 11 Python
Python 迭代器与生成器实例详解
May 18 Python
Django框架教程之正则表达式URL误区详解
Jan 28 Python
python 找出list中最大或者最小几个数的索引方法
Oct 30 Python
详解Django+Uwsgi+Nginx 实现生产环境部署
Nov 06 Python
python 用opencv调用训练好的模型进行识别的方法
Dec 07 Python
详解用Python练习画个美队盾牌
Mar 23 Python
Python实现将HTML转成PDF的方法分析
May 04 Python
python3+PyQt5 数据库编程--增删改实例
Jun 17 Python
Python+Dlib+Opencv实现人脸采集并表情判别功能的代码
Jul 01 Python
python 实现socket服务端并发的四种方式
Dec 14 Python
python创建字典及相关管理操作
Apr 13 Python
Python实现的破解字符串找茬游戏算法示例
Sep 25 #Python
Python实现破解猜数游戏算法示例
Sep 25 #Python
Python基于identicon库创建类似Github上用的头像功能
Sep 25 #Python
python3使用requests模块爬取页面内容的实战演练
Sep 25 #Python
python中通过预先编译正则表达式提高效率
Sep 25 #Python
python之Character string(实例讲解)
Sep 25 #Python
python利用正则表达式搜索单词示例代码
Sep 24 #Python
You might like
解析linux下安装memcacheq(mcq)全过程笔记
2013/06/27 PHP
php递归删除指定文件夹的方法小结
2015/04/20 PHP
PHP实现UTF8二进制及明文字符串的转化功能示例
2017/11/20 PHP
JAVASCRIPT 对象的创建与使用
2021/03/09 Javascript
javascript jq 弹出层实例
2013/08/25 Javascript
js中的for如何实现foreach中的遍历
2014/05/31 Javascript
jQuery中wrapAll()方法用法实例
2015/01/16 Javascript
微信小程序 swiper制作tab切换实现附源码
2017/01/21 Javascript
JavaScript设计模式之单例模式详解
2017/06/09 Javascript
JS检测window.open打开的窗口是否关闭
2017/06/25 Javascript
探究react-native 源码的图片缓存问题
2017/08/24 Javascript
利用ES6的Promise.all实现至少请求多长时间的实例
2017/08/28 Javascript
vue双向绑定数据限制长度的方法
2019/11/04 Javascript
vue+echarts实现动态折线图的方法与注意
2020/09/01 Javascript
浅谈nuxtjs校验登录中间件和混入(mixin)
2020/11/06 Javascript
[01:44]《为梦想出发》—联想杯DOTA2完美世界全国高校联赛
2015/09/30 DOTA
[04:19]DOTA2完美大师赛第四天精彩集锦
2017/11/26 DOTA
Python 26进制计算实现方法
2015/05/28 Python
黑科技 Python脚本帮你找出微信上删除你好友的人
2016/01/07 Python
Python中datetime模块参考手册
2017/01/13 Python
python中MethodType方法介绍与使用示例
2017/08/03 Python
Python导入模块时遇到的错误分析
2017/08/30 Python
python的变量与赋值详细分析
2017/11/08 Python
Python中矩阵库Numpy基本操作详解
2017/11/21 Python
Python decorator拦截器代码实例解析
2020/04/04 Python
css3 iphone玻璃透明气泡完美实现
2013/03/20 HTML / CSS
Giglio美国站:意大利奢侈品购物网
2018/02/10 全球购物
学术会议邀请函范文
2014/01/22 职场文书
餐厅销售主管职责范本
2014/02/19 职场文书
员工安全承诺书
2014/05/22 职场文书
八年级英语教学计划
2015/01/23 职场文书
学习焦裕禄观后感
2015/06/09 职场文书
企业催款函范本
2015/06/24 职场文书
Python初学者必备的文件读写指南
2021/06/23 Python
JavaScript最完整的深浅拷贝实现方式详解
2022/02/28 Javascript
Nginx图片服务器配置之后图片访问404的问题解决
2022/03/21 Servers