美文网首页scrapy
Scrapy爬虫——xpath与css选择器详解

Scrapy爬虫——xpath与css选择器详解

作者: youyuge | 来源:发表于2017-09-18 21:49 被阅读0次

有条件的请支持慕课实战正版课程,本blog仅仅是归纳总结,自用。

一、xpath部分

1.1 xpath简介

xpath简介.png

1.2 xpath语法

  • 子元素:仅仅指节点下面一层的元素
  • 后代元素:指标签下面任意层级的元素
  • 父元素、祖先(先辈)元素同理。
xpath语法图

1.3 xpath谓语语法

谓语(Predicates)谓语用来查找某个特定的节点或者包含某个指定的值的节点。谓语被嵌在方括号中。

xpathwei'yu

1.4 xpath其他语法

通配符 描述
* 匹配任何元素节点。
@* 匹配任何属性节点。
node() 匹配任何类型的节点。
xpath其他语法

二、css选择器

css选择器 css选择器2 css选择器3

三、scrapy选择器实战

这里是它的HTML源码:

<html>
 <head>
  <base href='http://example.com/' />
  <title>Example website</title>
 </head>
 <body>
  <div id='images'>
   <a href='image1.html'>Name: My image 1 <br />![](image1_thumb.jpg)</a>
   <a href='image2.html'>Name: My image 2 <br />![](image2_thumb.jpg)</a>
   <a href='image3.html'>Name: My image 3 <br />![](image3_thumb.jpg)</a>
   <a href='image4.html'>Name: My image 4 <br />![](image4_thumb.jpg)</a>
   <a href='image5.html'>Name: My image 5 <br />![](image5_thumb.jpg)</a>
  </div>
 </body>
</html>

3.1 构造选择器

首先, 我们打开shell:

scrapy shell http://doc.scrapy.org/en/latest/_static/selectors-sample1.html
  • 接着,当shell载入后,您将获得名为response
    的shell变量,其为响应的response, 并且在其 response.selector属性上绑定了一个 selector
  • 因为我们处理的是HTML,选择器将自动使用HTML语法分析。
  • 那么,通过查看 HTML code 该页面的源码,我们构建一个XPath来选择title标签内的文字:
>>> response.selector.xpath('//title/text()')
[<Selector (text) xpath=//title/text()>]
  • 由于在response中使用XPath、CSS查询十分普遍,因此,Scrapy提供了两个实用的快捷方式: response.xpath()response.css():
>>> response.xpath('//title/text()')
[<Selector (text) xpath=//title/text()>]
>>> response.css('title::text')
[<Selector (text) xpath=//title/text()>]
  • 如你所见, .xpath().css()方法返回一个类 SelectorList 的实例, 它是一个新选择器的列表。这个API可以用来快速的提取嵌套数据。

  • 为了提取真实的原文数据,你需要调用 .extract()方法如下:

>>> response.xpath('//title/text()').extract()
[u'Example website']
  • 如果想要提取到第一个匹配到的元素, 必须调用 .extract_first() selector:
>>> response.xpath('//div[@id="images"]/a/text()').extract_first()
u'Name: My image 1 '
  • 现在我们将得到根URL(base URL)和一些图片链接:
>>> response.xpath('//base/@href').extract()
[u'http://example.com/']

>>> response.css('base::attr(href)').extract()
[u'http://example.com/']

>>> response.xpath('//a[contains(@href, "image")]/@href').extract()
[u'image1.html',
 u'image2.html',
 u'image3.html',
 u'image4.html',
 u'image5.html']

>>> response.css('a[href*=image]::attr(href)').extract()
[u'image1.html',
 u'image2.html',
 u'image3.html',
 u'image4.html',
 u'image5.html']

>>> response.xpath('//a[contains(@href, "image")]/img/@src').extract()
[u'image1_thumb.jpg',
 u'image2_thumb.jpg',
 u'image3_thumb.jpg',
 u'image4_thumb.jpg',
 u'image5_thumb.jpg']

>>> response.css('a[href*=image] img::attr(src)').extract()
[u'image1_thumb.jpg',
 u'image2_thumb.jpg',
 u'image3_thumb.jpg',
 u'image4_thumb.jpg',
 u'image5_thumb.jpg']

3.2选择器嵌套

  • 选择器方法( .xpath() or .css() )返回相同类型的选择器列表,因此你也可以对这些选择器调用选择器方法。下面是一个例子:
>>> links = response.xpath('//a[contains(@href, "image")]')
>>> links.extract()
[u'<a href="image1.html">Name: My image 1 <br>![](image1_thumb.jpg)</a>',
 u'<a href="image2.html">Name: My image 2 <br>![](image2_thumb.jpg)</a>',
 u'<a href="image3.html">Name: My image 3 <br>![](image3_thumb.jpg)</a>',
 u'<a href="image4.html">Name: My image 4 <br>![](image4_thumb.jpg)</a>',
 u'<a href="image5.html">Name: My image 5 <br>![](image5_thumb.jpg)</a>']

>>> for index, link in enumerate(links):
        args = (index, link.xpath('@href').extract(), link.xpath('img/@src').extract())
        print 'Link number %d points to url %s and image %s' % args

Link number 0 points to url [u'image1.html'] and image [u'image1_thumb.jpg']
Link number 1 points to url [u'image2.html'] and image [u'image2_thumb.jpg']
Link number 2 points to url [u'image3.html'] and image [u'image3_thumb.jpg']
Link number 3 points to url [u'image4.html'] and image [u'image4_thumb.jpg']
Link number 4 points to url [u'image5.html'] and image [u'image5_thumb.jpg']

3.3 结合正则表达式使用选择器(selectors)

  • Selector 也有一个 .re()方法,用来通过正则表达式来提取数据。然而,不同于使用 .xpath() 或者 .css() 方法, .re() 方法返回unicode字符串的列表。所以你无法构造嵌套式的 .re() 调用。

  • 下面是一个例子,从上面的 HTML code 中提取图像名字:

>>> response.xpath('//a[contains(@href, "image")]/text()').re(r'Name:\s*(.*)')
[u'My image 1',
 u'My image 2',
 u'My image 3',
 u'My image 4',
 u'My image 5']
  • 另外还有一个糅合了 .extract_first().re() 的函数 .re_first() . 使用该函数可以提取第一个匹配到的字符串:
>>> response.xpath('//a[contains(@href, "image")]/text()').re_first(r'Name:\s*(.*)')
u'My image 1'

相关文章

  • Scrapy爬虫——xpath与css选择器详解

    有条件的请支持慕课实战正版课程,本blog仅仅是归纳总结,自用。 一、xpath部分 1.1 xpath简介 1....

  • Xpath和CSS选择器语法整合

    最近项目中需要用Scrapy写一个爬虫,用到了许多xpath和css选择器的语法,因此在此做一个整合,基本的语法就...

  • scrapy前了解Xpath

    写爬虫时候节点选择器可以用xpath,css,beautifulsoup。而我们要介绍的是xpath路径写法。xp...

  • 第四章 网站内容爬取之xpath选择器在某个网页上的实践

    如何通过xpath在html中取出想要的值:scrapy根据xml提供了一套简洁的通过xpath或者css选择器来...

  • 爬虫-python-scrapy框架基本命令

    爬虫-python-scrapy框架基本命令 创建一个项目 抓取页面 网页抓取shell XPath(选择器节点)...

  • CSS选择器

    CSS 元素选择器CSS 选择器分组CSS 类选择器详解CSS ID 选择器详解CSS 属性选择器详解CSS 后代...

  • scrapy实战笔记

    一,基础 scrapy优势:异步IO,性能强;内置功能丰富(css,xpath);易扩展爬虫简要步骤:URL分析,...

  • Scrapy总结

    目录 Scrapy架构 Scrapy爬虫能解决什么问题 Scrapy爬虫注意事项 Login问题 xpath工具 ...

  • CSS选择器

    除了正则和XPATH以外,scrapy中还支持第三种选择器,那就是CSS选择器;下面就一一介绍常见的CSS选择器的...

  • day09 scrapy的用法 和

    Selector 是 Scrapy的选择器器,基于lxml构建,⽀支持xpath, css, 正则表达式匹配scr...

网友评论

    本文标题:Scrapy爬虫——xpath与css选择器详解

    本文链接:https://www.haomeiwen.com/subject/zbcbsxtx.html