xpath选择器的使用

Posted surpass123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了xpath选择器的使用相关的知识,希望对你有一定的参考价值。

xpath简介

xpath是一门可以在xml文档中查找信息的语言
/: 从根节点选取
//: 不管位置,直接找
/@href 属性名
/text()

xpath选择器操作

doc=‘‘‘
<html>
 <head>
  <base href=‘http://example.com/‘ />
  <title>Example website</title>
 </head>
 <body>
  <div id=‘images‘>
   <a href=‘image1.html‘ aa=‘bb‘>Name: My image 1 <br /><img src=‘image1_thumb.jpg‘ /></a>
   <a href=‘image2.html‘>Name: My image 2 <br /><img src=‘image2_thumb.jpg‘ /></a>
   <a href=‘image3.html‘>Name: My image 3 <br /><img src=‘image3_thumb.jpg‘ /></a>
   <a href=‘image4.html‘>Name: My image 4 <br /><img src=‘image4_thumb.jpg‘ /></a>
   <a href=‘image5.html‘ class=‘li li-item‘ name=‘items‘>Name: My image 5 <br /><img src=‘image5_thumb.jpg‘ /></a>
   <a href=‘image6.html‘ name=‘items‘><span><h5>test</h5></span>Name: My image 6 <br /><img src=‘image6_thumb.jpg‘ /></a>
  </div>
 </body>
</html>
‘‘‘

使用方式

# 方式一
from lxml import etree
html = etree.parse(‘source.html‘,parser=etree.HTMLParser()) # 打开source.html
# 方式二
from lxml import etree
html = etree.HTML(doc)
  • 查所有的节点
query_list = html.xpath(‘//*‘) 
  • 查询指定的节点
query_list = html.xpath(‘//head‘) # [<Element head at 0x7efd6ee663c0>]
  • 查询子节点,子孙节点
query_list = html.xpath(‘//div/a‘) 
query_list = html.xpath(‘//body/a‘) #[]
query_list = html.xpath(‘//body//a‘)
  • 父节点
query_list = html.xpath(‘//body//a[@href="image2.html"]/..‘) # [<Element div at 0x7f46fde88300>]

query_list = html.xpath(‘//body//a[1]/..‘)
# 也可以这样
query_list = html.xpath(‘//body//a[1]/parent::*‘)
  • 属性匹配
query_list = html.xpath(‘//body//a[@href="image2.html"]‘)
  • 文本获取text() (重要)
query_list = html.xpath(‘//body//a[@href="image2.html"]/text()‘)
# [‘Name: My image 2 ‘]
query_list = html.xpath(‘//body//a/text()‘)
# [‘Name: My image 1 ‘, ‘Name: My image 2 ‘, ‘Name: My image 3 ‘, ‘Name: My image 4 ‘, ‘Name: My image 5 ‘, ‘Name: My image 6 ‘]
  • 属性获取 @href
query_list = html.xpath(‘//body//a/@href‘) # [‘image1.html‘, ‘image2.html‘, ‘image3.html‘, ‘image4.html‘, ‘image5.html‘, ‘image6.html‘]

# 注意列表是从1开始取值,不是0
query_list = html.xpath(‘//body//a[2]/@href‘) #[‘image2.html‘]
  • 属性多值匹配
# 当a标签有多个属性值,直接匹配就不行了,需要使用模糊匹配
query_list = html.xpath(‘//body//a[@class="li"]‘) #[]
query_list = html.xpath(‘//body//a[contains(@class,"li")]‘) #[<Element a at 0x7fcf223f90c0>]

query_list = html.xpath(‘//body//a[contains(@class,"li")]/text()‘) #[‘Name: My image 5 ‘]
  • 多属性匹配
query_list = html.xpath(‘//body//a[contains(@class,"li") or @name="items"]‘)

query_list = html.xpath(‘//body//a[contains(@class,"li") and @name="items"]/text()‘)

query_list = html.xpath(‘//body//a[contains(@class,"li")]/text()‘)
  • 按顺序进行选择
# query_list = html.xpath(‘//a[2]/text()‘)
# query_list = html.xpath(‘//a[2]/@href‘)
# 取最后一个
# query_list = html.xpath(‘//a[last()]/@href‘)
# 位置小于3的
# query_list = html.xpath(‘//a[position()<3]/@href‘)
# 倒数第二个
# query_list = html.xpath(‘//a[last()-2]/@href‘)
  • 节点轴选择
# ancestor:祖先节点
# 使用了* 获取所有祖先节点
# query_list = html.xpath(‘//a/ancestor::*‘)
# # 获取祖先节点中的div
# query_list = html.xpath(‘//a/ancestor::div‘)
# attribute:属性值
# query_list = html.xpath(‘//a[1]/attribute::*‘)
# query_list = html.xpath(‘//a[1]/@aa‘)
# child:直接子节点
# query_list = html.xpath(‘//a[1]/child::*‘)
# query_list = html.xpath(‘//a[1]/child::img/@src‘)
# descendant:所有子孙节点
# query_list = html.xpath(‘//a[6]/descendant::*‘)
# query_list = html.xpath(‘//a[6]/descendant::h5/text()‘)
# following:当前节点之后所有节点(兄弟节点和兄弟内部的节点)
# query_list = html.xpath(‘//a[1]/following::*‘)
# query_list = html.xpath(‘//a[1]/following::*[1]/@href‘)
# following-sibling:当前节点之后同级节点(只找兄弟)
# query_list = html.xpath(‘//a[1]/following-sibling::*‘)
# query_list = html.xpath(‘//a[1]/following-sibling::a‘)
# query_list = html.xpath(‘//a[1]/following-sibling::*[2]‘)
# query_list = html.xpath(‘//a[1]/following-sibling::*[2]/@href‘)

以上是关于xpath选择器的使用的主要内容,如果未能解决你的问题,请参考以下文章

XPath 中 CSS 多重选择器的等价物

uiautomator的xpath选择器

Python爬虫从入门到放弃(十四)之 Scrapy框架中选择器的用法

使用 xpath 同时选择属性和内容?

可缩放时间轴和录像片段选择器的实现

NightwatchJS 中的 xPath 问题