zoukankan      html  css  js  c++  java
  • scrapy系统学习(1)--概要

    本文操作环境:ubuntu14.04

    一.安装Scrapy/Mysql/MySQLdb

    • 参照官网教程安装Scrapy
    #sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 627220E7
    #echo 'deb http://archive.scrapy.org/ubuntu scrapy main' | sudo tee /etc/apt/sources.list.d/scrapy.list
    #sudo apt-get update && sudo apt-get install scrapy-0.25
    • 安装Mysql
    #apt-get install mysql-server
    • 安装第三方库MySQLdb
    #apt-get install python2.7-mysqldb

    二.爬虫的目标是抓取

    start一个爬虫项目,目标是抓取http://www.mininova.org/today 界面上每日更新的内容并以json格式保存。

    root@alexknight:/home# scrapy startproject mininova
    
    mininova/
    ├── mininova
    │   ├── __init__.py
    │   ├── items.py
    │   ├── pipelines.py
    │   ├── settings.py
    │   └── spiders
    │      └── __init__.py
    └── scrapy.cfg

    items一般与pipelines.py一起使用,items可以定义自己需要抓取的格式,pipelines.py可以定义抓取内容。

    items.py:

    # -*- coding: utf-8 -*-
    
    # Define here the models for your scraped items
    #
    # See documentation in:
    # http://doc.scrapy.org/en/latest/topics/items.html
    
    import scrapy
    
    class MininovaItem(scrapy.Item):
        # define the fields for your item here like:
        # name = scrapy.Field()
            url=scrapy.Field()
            name=scrapy.Field()
            description=scrapy.Field()
            size=scrapy.Field()

    在spider新建文件mininova_spider.py:

    from scrapy.contrib.spiders import CrawlSpider, Rule
    from scrapy.contrib.linkextractors import LinkExtractor
    from mininova.items import MininovaItem
    class MininovaSpider(CrawlSpider):
            name='mininova'
            allowed_domains=['mininova.org']
            start_urls = ['http://www.mininova.org/today']
            rules = [Rule(LinkExtractor(allow=['/tor/d+']), 'parse_torrent')]
    
            def parse_torrent(self, response):
                    #global MininovaItem
                    torrent = MininovaItem()
                    torrent['url'] = response.url
                    torrent['name'] = response.xpath("//h1/text()").extract()
                    torrent['description'] = response.xpath("//div[@id='description']").extract()
                    torrent['size'] = response.xpath("//div[@id='info-left']/p[2]/text()[2]").extract()
                    return torrent

    将数据json化

    root@alexknight:/home/mininova#scrapy crawl mininova -o scraped_data.json
    root@alexknight:/home/mininova#vim scraped_data.json
    [{"url": "http://www.mininova.org/tor/13278887", "size": [], "description": ["<div id="description">
    
    <iframe id="share-facebook" src="http://www.facebook.com/plugins/like.php?href=http://www.mininova.org/tor/13278887&amp;layout=box_count&amp;show_faces=false&amp;width=50&amp;action=like&amp;colorscheme=light&amp;height=65" scrolling="no" frameborder="0"></iframe>
    
    Young Lucid's debut release features Joell Oritz, one quarter of the Shady Recordsu2019 super group, Slaughterhouse. The emotional production from 2 Deep &amp; MeccaGodZilla set the tone for the lyrical duo as they trade bars about a world they long to escape. u201cRunawayu201d is a mere preview of Young Lucidu2019s upcoming project, u201cLucid Dreamsu201d which is slated for a 2015 release.<br>
    <br>
    <a target="_blank" rel="nofollow" href="http://www.younglucid.com/">www.younglucid.com</a><br>
    <a target="_blank" rel="nofollow" href="http://www.meccagodzilla.com">www.meccagodzilla.com</a><br>
    <br>
    <div class="clear-left"></div>
    </div>"], "name": ["NEW: Runaway Ft. Joell Ortiz by Young Lucid "]}]
  • 相关阅读:
    2018-2019-2 20175310 个人项目总结报告
    2018-2019-2 20175310 个人项目报告5--勾股数
    2018-2019-2 20175310 个人项目报告6--四方定理
    2018-2019-2 20175310 个人项目报告7--尼科彻斯定理
    #2019-2020-4 《Java 程序设计》第十周总结
    数据库MySQL(20175229张智敏)
    #实验三 敏捷开发与XP实践---实验报告
    课下必做MyCP
    #2019-2020-4 《Java 程序设计》第九周总结
    #2019-2020-4 《Java 程序设计》第八周总结
  • 原文地址:https://www.cnblogs.com/alexkn/p/4296012.html
Copyright © 2011-2022 走看看