爬虫去重策略:

爬虫去重策略:

  1. 将访问过的url保存到数据库中。
    最简单的方式。即使数据库有缓存,但每次都从数据库中查询url,效率低下。

  2. 将访问过的url保存到set中,只需要o(1)的代价就可以查询url

  • 占用内存过高
  • 对小型爬虫,假设存储100000000条url数据,每条数据50个字符,Python3.x采用Unicode编码,每个字符2byte,则占用内存100000050字符2byte/1024/1024/1024 = 9.3G
  1. url经过md5等方法哈希后保存到set中
  • 将字符缩短到固定的长度,并且不会重复
  • scrapy采用的是这种方式
  1. 使用bitmap方法,将访问过的url通过hash函数映射到某一位(bit)
  • 缺点:冲突会非常高
  • 同上,存储100000000条url数据,采用bitmap方法1条数据对应1bit,则理想情况下占用内存100000000/8bit/1024/1024/ = 11.9Mb,这里不考虑冲突。
  1. 使用bloomfilter方法对bitmap进行改进,通过多重hash函数降低冲突

列表生成式——去重

>>> tag_list = ['x','y','z']
>>> tag_list = [element for element in tag_list if not element.strip().endswith('y')]
>>> tag_list
['x', 'z']
>>> tags = ','.join(tag_list)
>>> tags
'x,z'
>>>

转载于:https://www.cnblogs.com/onefine/p/10499364.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值