4

我有一个网络爬虫,可以爬取网页上的新闻报道。

我知道如何使用 XpathSelector 从页面中的元素中抓取某些信息。

但是我似乎无法弄清楚如何存储刚刚抓取的页面的 URL。

class spidey(CrawlSpider):
    name = 'spidey'
    start_urls = ['http://nytimes.com'] # urls from which the spider will start crawling
    rules = [Rule(SgmlLinkExtractor(allow=[r'page/\d+']), follow=True), 
        # r'page/\d+' : regular expression for http://nytimes.com/page/X URLs
        Rule(SgmlLinkExtractor(allow=[r'\d{4}/\d{2}/\w+']), callback='parse_articles')]
        # r'\d{4}/\d{2}/\w+' : regular expression for http://nytimes.com/YYYY/MM/title URLs

我想存储通过这些规则的每个链接。

我需要添加什么到 parse_articles 以将链接存储在我的项目中?

def parse_articles(self, response):
    item = SpideyItem()
    item['link'] = ???
    return item
4

1 回答 1

6

response.url 是您要查找的内容。

请参阅有关响应对象的文档并检查这个简单的示例。

于 2013-02-27T07:05:15.777 回答