A Powerful Spider(Web Crawler) System in Python.
Go to file
2020-07-26 16:57:30 -07:00
.github
data
docs added https to couchdb + cleanup + added couchdb to docs 2019-11-08 10:57:10 +01:00
pyspider fix test break because couchdb failing to start 2020-07-26 16:20:28 -07:00
tests try to use non-auth for CouchDB test 2020-07-26 16:57:30 -07:00
tools
.coveragerc
.gitignore
.travis.yml try to use non-auth for CouchDB test 2020-07-26 16:57:30 -07:00
config_example.json improve docker-compose sample 2019-11-13 22:16:04 -08:00
docker-compose.yaml improve docker-compose sample 2019-11-13 22:16:04 -08:00
Dockerfile
LICENSE
MANIFEST.in
mkdocs.yml
README.md remove demo link 2020-07-26 14:48:40 -07:00
requirements.txt upgraded pika 2019-10-25 15:27:07 +02:00
run.py
setup.py fix test break because couchdb failing to start 2020-07-26 16:20:28 -07:00
tox.ini fix test break because couchdb failing to start 2020-07-26 16:20:28 -07:00

pyspider Build Status Coverage Status

A Powerful Spider(Web Crawler) System in Python.

Tutorial: http://docs.pyspider.org/en/latest/tutorial/
Documentation: http://docs.pyspider.org/
Release notes: https://github.com/binux/pyspider/releases

Sample Code

from pyspider.libs.base_handler import *


class Handler(BaseHandler):
    crawl_config = {
    }

    @every(minutes=24 * 60)
    def on_start(self):
        self.crawl('http://scrapy.org/', callback=self.index_page)

    @config(age=10 * 24 * 60 * 60)
    def index_page(self, response):
        for each in response.doc('a[href^="http"]').items():
            self.crawl(each.attr.href, callback=self.detail_page)

    def detail_page(self, response):
        return {
            "url": response.url,
            "title": response.doc('title').text(),
        }

Installation

WARNING: WebUI is open to the public by default, it can be used to execute any command which may harm your system. Please use it in an internal network or enable need-auth for webui.

Quickstart: http://docs.pyspider.org/en/latest/Quickstart/

Contribute

TODO

v0.4.0

  • a visual scraping interface like portia

License

Licensed under the Apache License, Version 2.0