Muovi il tuo dannato parse

Web Scraping in Python

Thomas Laetsch

Data Scientist, NYU

Di nuovo

class DCspider( scrapy.Spider ):
    name = "dcspider"

    def start_requests( self ):
        urls = [ 'https://www.datacamp.com/courses/all' ]
        for url in urls:
            yield scrapy.Request( url = url, callback = self.parse )

    def parse( self, response ):
        # simple example: write out the html
        html_file = 'DC_courses.html'
        with open( html_file, 'wb' ) as fout:
            fout.write( response.body )
Web Scraping in Python

Lo conosci già!

def parse( self, response ):

# input parsing code with response that you already know!
# output to a file, or...
# crawl the web!
Web Scraping in Python

Link dei corsi DataCamp: salva su file

class DCspider( scrapy.Spider ):
    name = "dcspider"

    def start_requests( self ):
        urls = [ 'https://www.datacamp.com/courses/all' ]
        for url in urls:
            yield scrapy.Request( url = url, callback = self.parse )

def parse( self, response ):
links = response.css('div.course-block > a::attr(href)').extract()
filepath = 'DC_links.csv' with open( filepath, 'w' ) as f: f.writelines( [link + '/n' for link in links] )
Web Scraping in Python

Link dei corsi DataCamp: effettua di nuovo il parse

class DCspider( scrapy.Spider ):
    name = "dcspider"

    def start_requests( self ):
        urls = [ 'https://www.datacamp.com/courses/all' ]
        for url in urls:
            yield scrapy.Request( url = url, callback = self.parse )

def parse( self, response ):
links = response.css('div.course-block > a::attr(href)').extract()
for link in links: yield response.follow( url = link, callback = self.parse2 )
def parse2( self, response ): # parse the course sites here!
Web Scraping in Python

Un ragno che segue link nel sito DataCamp.

Web Scraping in Python

Johnny Parsin'

Web Scraping in Python

Preparing Video For Download...