scrapy正则表达式返回不匹配的网址

时间:2015-09-24 02:52:40

标签: python regex web-scraping scrapy

我的蜘蛛代码是:

class TryItem(Item):
    url = Field()

class BbcSpiderSpider(CrawlSpider):
    name = "bbc_spider"
    allowed_domains = ["www.bbc.com"]
    start_urls = ['http://www.bbc.com/sport/0/tennis']

    rules = (Rule(LinkExtractor(allow=['.*sport\/0\/tennis\/\d{8}']), callback='parse_item', follow=True),)

    def parse_item(self, response):
        Item = TryItem()
        Item['url'] = response.url
        yield Item

通过这只蜘蛛,我试图收集所有关于网球的文章的网址。我使用csv代码:

scrapy crawl bbc_spier -o bbc.csv -t csv

我正在寻找的输出是:

http://www.bbc.com/sport/0/tennis/34322294
http://www.bbc.com/sport/0/tennis/14322295
...
http://www.bbc.com/sport/0/tennis/12345678

但是,蜘蛛也会返回不匹配的网址,例如:

http://www.bbc.com/sport/0/tennis/29604652?print=true
http://www.bbc.com/sport/0/tennis/34252190?comments_page=11&filter=none&initial_page_size=10&sortBy=Created&sortOrder=Descending

有什么建议吗?感谢

1 个答案:

答案 0 :(得分:2)

不要让蜘蛛通过强制网址在8位数后结束来跟踪不需要的网址:

.*sport\/0\/tennis\/\d{8}$
#              IMPORTANT ^