当前位置: 首页 > news >正文

网站平台怎么做的没干过网络推广能干吗

网站平台怎么做的,没干过网络推广能干吗,日本世界排名第几,上海做网站哪家公司好python爬虫-url管理器 url管理器的作用python实现 url管理器的作用 在Python爬虫中,URL管理器(URL Manager)是一个重要的组件,用于有效管理爬取过程中所涉及的URL。它主要负责以下几个方面的任务: URL去重(…

python爬虫-url管理器

  • url管理器的作用
  • python实现

url管理器的作用

  • 在Python爬虫中,URL管理器(URL Manager)是一个重要的组件,用于有效管理爬取过程中所涉及的URL。它主要负责以下几个方面的任务:

    • URL去重(去重复):在爬取过程中,会遇到相同的URL被重复爬取的情况,这不仅浪费了时间和资源,还可能导致数据重复。URL管理器通过维护一个已经爬取过的URL集合,确保每个URL只被爬取一次,避免重复。

    • URL调度(调度顺序):爬虫需要决定下一个要爬取的URL是哪个。URL管理器负责根据一定的策略,选择下一个要爬取的URL,可以使用先进先出(FIFO)、后进先出(LIFO)、优先级队列等不同的调度策略。

    • 新URL添加:当从一个网页中解析出新的URL时,URL管理器负责将这些新URL添加到待爬取的URL队列中,以确保爬虫能够持续地探索新的页面。

    • URL状态管理:URL管理器可以记录每个URL的状态,例如是否已经爬取、是否成功、失败次数等。这有助于在后续的爬取过程中进行优化和错误处理。

    • 数据持久化:在爬虫运行结束后,URL管理器通常会将已经爬取的URL保存下来,以便下次运行时恢复之前的状态。

  • URL管理器通常由两个部分组成:待爬取URL队列(待爬取URL集合)和已爬取URL集合。这两部分工作协同,确保爬虫能够高效地运行,不重复爬取URL,同时按照合适的策略调度URL。

综上所述,URL管理器在爬虫中起到了整合、协调、去重和调度的重要作用,帮助爬虫更加高效地获取所需的信息。

python实现

class UrlManager():"""url管理器"""def __init__(self):# 初始化待爬取url和已爬取urlself.new_urls = set()self.old_urls = set()def add_new_url(self, url):"""添加新的url"""if (url is None) or (len(url) == 0):return("Error! The URL to be added is empty")if (url in self.new_urls) or (url in self.old_urls):return('Error! The URL to be added already exists')self.new_urls.add(url)def add_new_urls(self, urls):"""批量添加新的url"""if (urls is None) or (len(urls) == 0):return("Error! The URLs to be added is empty")for url in urls:self.add_new_url(url)def get_url(self):"""获取爬取url,并记录"""if self.find_new_url():url = self.new_urls.pop()self.old_urls.add(url)return urlelse:return("Crawling completed, the URL to be crawled is empty")def find_new_url(self):return len(self.new_urls) > 0if __name__ == "__main__":url_manager = UrlManager()url_manager.add_new_url('url1')url_manager.add_new_urls(['url1','url2'])print("new_urls:{}, old_urls:{}".format(url_manager.new_urls, url_manager.old_urls))print("+"*30)new_url = url_manager.get_url()print("new_urls:{}, old_urls:{}".format(url_manager.new_urls, url_manager.old_urls))print("+"*30)new_url = url_manager.get_url()print("new_urls:{}, old_urls:{}".format(url_manager.new_urls, url_manager.old_urls))print("+"*30)print(url_manager.find_new_url())"""
output:
new_urls:{'url2', 'url1'}, old_urls:set()
++++++++++++++++++++++++++++++
new_urls:{'url1'}, old_urls:{'url2'}
++++++++++++++++++++++++++++++
new_urls:set(), old_urls:{'url2', 'url1'}
++++++++++++++++++++++++++++++
False
"""
http://www.hkea.cn/news/242272/

相关文章:

  • 番禺做网站自媒体发布平台有哪些
  • 用dede做的网站首页电子商务网络营销
  • 最好的做任务赚钱网站网络域名怎么查
  • 建设部规范网站百度app关键词优化
  • 骏域网站百度怎么收录网站
  • 网站robots.txt查看九江seo公司
  • 建设阿里妈妈网站搜索引擎排名优化seo
  • 自学网站建设作业创建网站免费
  • 营销网站定制的优势成品网站源码的优化技巧
  • 高职学院网站建设方案广告制作
  • table表格 做的网站营销案例分析报告模板
  • pc端网站做移动适配教育培训机构管理系统
  • 页游传奇排行榜无锡seo优化公司
  • 广西南宁网站设计百度seo算法
  • 网站建设服务怎么样近期国内热点新闻事件
  • 阿里巴巴网站国际站建设seo托管服务
  • 企业网站优化之如何做需求分析网奇seo赚钱培训
  • 施工企业会计制度收入确认规定百度自然排名优化
  • 校园网站建设意义网络营销的特点有哪些
  • 内江做网站哪里便宜google搜索关键词热度
  • 福建省建设银行招聘网站网络推广员压力大吗
  • 动态网站订单怎么做搜索引擎优化营销
  • html5行业网站最近有哪些新闻
  • 做网站业务的怎么寻找客户在哪里打广告效果最好
  • 广东深圳seo服务内容
  • 做网站怎么备案网络服务有限公司
  • 网站主页特效欣赏百度官网下载电脑版
  • php mysql开发网站开发任何小说都能搜到的软件
  • the7 wordpress主题宁波seo外包费用
  • 云南建筑培训网seo刷点击软件