python万能爬虫_Python爬虫中的万能过滤规则

def filter_tags(htmlstr):

# 先过滤CDATA

re_cdata = re.compile('//]*//\]\]>', 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('
') # 处理换行

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

def replaceCharEntity(htmlstr):

CHAR_ENTITIES = {'nbsp': ' ', '160': ' ',

'lt': '<', '60': '<',

'gt': '>', '62': '>',

'amp': '&', '38': '&',

'quot': '"', '34': '"', }

re_charEntity = re.compile(r'?(?P\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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值