【发布时间】:2012-09-21 04:54:10
【问题描述】:
我正在尝试让 Scrapy Crawlspider 的“规则”部分正常工作。
我找到了返回我想要关注的链接的xpath。这是
//*[@class="course_detail"]//td[4]/a/@href
它总共返回大约 2700 个 URL。
基本上,我试图告诉蜘蛛遵循与xpath 匹配的所有内容,但我无法让以下代码正常工作:
rules = (
Rule(SgmlLinkExtractor( allow=[r'.*'],
restrict_xpaths='//*[@class="course_detail"]//td[4]/a/@href'
),
callback='parse_item'
),
)
我没有收到任何错误,但蜘蛛似乎没有越过我在start_urls 中定义的页面。
编辑:想通了!只需要删除@href。海登的代码也有帮助,所以我将答案奖励给他。
【问题讨论】:
标签: python regex screen-scraping web-scraping scrapy