纯python robots.txt解析器,支持现代约定

Protego的Python项目详细描述


protego

build-badgemade-with-python

概述

protego是一个纯python robots.txt解析器,支持现代约定。

要求

  • Python2.7或Python3.5+
  • 适用于Linux、Windows、Mac OSX、BSD

安装

要安装protego,只需使用pip:

pip install protego

用法

>>>fromprotegoimportProtego>>>robotstxt="""... User-agent: *... Disallow: /... Allow: /about... Allow: /account... Disallow: /account/contact$... Disallow: /account/*/profile... Crawl-delay: 4... Request-rate: 10/1m                 # 10 requests every 1 minute... ... Sitemap: http://example.com/sitemap-index.xml... Host: http://example.co.in... """>>>rp=Protego.parse(robotstxt)>>>rp.can_fetch("http://example.com/profiles","mybot")False>>>rp.can_fetch("http://example.com/about","mybot")True>>>rp.can_fetch("http://example.com/account","mybot")True>>>rp.can_fetch("http://example.com/account/myuser/profile","mybot")False>>>rp.can_fetch("http://example.com/account/contact","mybot")False>>>rp.crawl_delay("mybot")4.0>>>rp.request_rate("mybot")RequestRate(requests=10,seconds=60,start_time=None,end_time=None)>>>list(rp.sitemaps)['http://example.com/sitemap-index.xml']>>>rp.preferred_host'http://example.co.in'

使用protego和Requests

>>>fromprotegoimportProtego>>>importrequests>>>r=requests.get("https://google.com/robots.txt")>>>rp=Protego.parse(r.text)>>>rp.can_fetch("https://google.com/search","mybot")False>>>rp.can_fetch("https://google.com/search/about","mybot")True>>>list(rp.sitemaps)['https://www.google.com/sitemap.xml']

文件

protego.Protego

属性

  • sitemaps{list_iterator中指定的站点地图列表。
  • preferred_host{string}在robots.txt中指定的首选主机。

方法

  • parse(robotstxt_body)解析robots.txt,并返回protego.Protego的新实例。
  • can_fetch(url, user_agent)如果用户代理可以获取url,则返回true,否则返回false。
  • crawl_delay(user_agent)将为用户代理指定的爬网延迟作为浮点值返回如果未指定任何内容,则返回none。
  • request_rate(user_agent)返回为用户代理指定的请求速率,作为命名元组RequestRate(requests, seconds, start_time, end_time)。如果未指定任何内容,则返回none。

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java FloatingAction按钮与RecyclerView中的CardView重叠   java如何计算CardLayout中的卡数   从远程系统上传MySQL数据库并访问Java应用程序   java调用堆栈如何处理带或不带返回类型的递归?   Springboot中的java组计数聚集   java如何在javafx textarea中使用richtextfx   获取与Mockito相关的错误时出现Java问题   java如何将JaxRS响应转换为Wiremock响应   Hadoop集群java。net ConnectionException:连接被拒绝错误   java如何加载文件私有文件类型是pem   java在元空间中的提升和加载的类   如何将系统属性传递给从HTML启动的Java小程序   java如何从网页中获取值并在主类中使用它?安卓应用   java在春天,advisor和aspect之间有什么区别?   java如何检测文件是否已重命名?   java消息驱动Bean何时使用