xpath寻找标签

语法格式如下

1 标签名   # 找xml中所有这个标签
2 /       # 只找一层
3 //      # 子子孙孙都会找
4 .       # 从当前路径下
5 ..      # 上一层
6 @属性名 # 找有这个属性的标签

数据准备

doc='''
<html>
 <head>
  <base href='http://example.com/' />
  <title>Example website</title>
 </head>
 <body>
  <div id='images'>
   <a href='image1.html' id='id_a' name='lqz'>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'  class='li'>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.HTML(doc) # 加载字符串
# html=etree.parse('search.html',etree.HTMLParser()) # 加载文件

1 所有节点

a=html.xpath('//*')
a=html.xpath('/*')

2 指定节点(结果为列表)

a=html.xpath('//head')

3 子节点,子孙节点

a=html.xpath('//div/a')
a=html.xpath('//body/a') # 无数据
a=html.xpath('//body//a')

4 父节点

a=html.xpath('//body//a[@href="image1.html"]/..')
a=html.xpath('//body//a[1]/..')  # 从1开始

# 也可以这样
a=html.xpath('//body//a[1]/parent::*')  # 找父亲---》父亲可以是任意标签
a=html.xpath('//body//a[1]/parent::div')  # 找父亲---》父亲是div标签

5 属性匹配

a=html.xpath('//a[@href="image1.html"]')

6 文本获取(重要)

a=html.xpath('//body//a[@href="image1.html"]/text()')

7 属性获取(重要)

a=html.xpath('//body//a/@href') # 拿所有a的href属性

# 注意从1 开始取(不是从0)
a=html.xpath('//body//a[1]/@href')

8 属性多值匹配

# a 标签有多个class类,直接匹配就不可以了,需要用contains
a=html.xpath('//body//a[@class="li"]') # 无法获取,原因:因为这个a有两个类
a=html.xpath('//body//a[contains(@class,"li")]')
a=html.xpath('//body//a[contains(@class,"li")]/text()')

9 多属性匹配

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

10 按序选择

a=html.xpath('//a[2]/text()')
a=html.xpath('//a[2]/@href')
# 取最后一个
a=html.xpath('//a[last()]/@href')
# 位置小于3的
a=html.xpath('//a[position()<3]/@href')
# 倒数第三个
a=html.xpath('//a[last()-2]/@href')

11 节点轴选择

# ancestor:祖先节点

# 使用了* 获取所有祖先节点
a=html.xpath('//a/ancestor::*')

# 获取祖先节点中的div
a=html.xpath('//a/ancestor::html')

# attribute:属性值
a=html.xpath('//a[1]/attribute::*')
a=html.xpath('//a[1]/attribute::id')

# child:直接子节点
a=html.xpath('//a[1]/child::*')
a=html.xpath('//a[1]/child::img')

# descendant:所有子孙节点
a=html.xpath('//a[6]/descendant::*')

# following:当前节点之后所有节点
a=html.xpath('//a[1]/following::*')
a=html.xpath('//a[1]/following::*[1]/@href')

# following-sibling:当前节点之后同级节点
a=html.xpath('//a[1]/following-sibling::*')
a=html.xpath('//a[1]/following-sibling::a')
a=html.xpath('//a[1]/following-sibling::*[2]')
a=html.xpath('//a[1]/following-sibling::*[2]/@href')

print(a)

posted @ 2024-02-22 15:00  wellplayed  阅读(47)  评论(0)    收藏  举报