Python之path的使用

小编 2026-06-19 阅读:750 评论:0
一.简介: XPath 是一门在 XML 文档中查找信息的语言。XPath 可用来在 XML 文档中对元素和属性进行遍历. 二.安装 pip install lxml 三.使用 / 从根标签...

一.简介:

XPath 是一门在 XML 文档中查找信息的语言。XPath 可用来在 XML 文档中对元素和属性进行遍历.

二.安装

pip install lxml

三.使用

/ 从根标签开始 必须具有严格的父子关系
// 从当前标签 后续节点含有即可选出
* 通配符 ,选择所有
//div/book[1]/title 选择div下第一个book标签的title元素
//div/book/title[@lang=\"zh\"]选择title属性含有lang且内容是zh的title元素
//div/book/title //book/title  //title  具有相同的结果,因为使用相对路径最终都指向title
//book/title/@* 将所有的属性值选择出来
//book/title/text()  将title的内容选择出来,使用内置text()函数
//a[@href=\"link1.html\" and @id=\"places_neighbours__row\"]/text()
//div/book[last()]/title/text() 将最后一个book元素选出
//div/book[price>39]/title 将book子标签price数值大于39的选择出来
//li[starts-with(@class,\'item\')] 将class属性前缀是item的li标签选出来
//title[contains(@lang,\'eng\')] 将title属性lang含有eng关键字的标签选出

四.示例:

首先需要导入需要的包

from lxml import etree

基本使用

from lxml import etree
 
wb_data = \"\"\"
        <div>
            <ul>
                 <li class=\"item-0\"><a href=\"link1.html\">first item</a></li>
                 <li class=\"item-1\"><a href=\"link2.html\">second item</a></li>
                 <li class=\"item-inactive\"><a href=\"link3.html\">third item</a></li>
                 <li class=\"item-1\"><a href=\"link4.html\">fourth item</a></li>
                 <li class=\"item-0\"><a href=\"link5.html\">fifth item</a>
             </ul>
         </div>
        \"\"\"
html = etree.HTML(wb_data)
print(html)
result = etree.tostring(html)
print(result.decode(\"utf-8\"))

从下面的结果来看,我们打印机html其实就是一个python对象,etree.tostring(html)则是不全里html的基本写法,补全了缺胳膊少腿的标签。

<Element html at 0x39e58f0>
<html><body><div>
            <ul>
                 <li class=\"item-0\"><a href=\"link1.html\">first item</a></li>
                 <li class=\"item-1\"><a href=\"link2.html\">second item</a></li>
                 <li class=\"item-inactive\"><a href=\"link3.html\">third item</a></li>
                 <li class=\"item-1\"><a href=\"link4.html\">fourth item</a></li>
                 <li class=\"item-0\"><a href=\"link5.html\">fifth item</a>
             </li></ul>
         </div>
        </body></html>

获取某个标签的内容(基本使用),注意,获取a标签的所有内容,a后面就不用再加正斜杠,否则报错。

写法一

html = etree.HTML(wb_data)
html_data = html.xpath(\'/html/body/div/ul/li/a\')
print(html)
for i in html_data:
    print(i.text)
 
 #打印结果
<Element html at 0x12fe4b8>
first item
second item
third item
fourth item
fifth item

写法二(直接在需要查找内容的标签后面加一个/text()就行)

html = etree.HTML(wb_data)
html_data = html.xpath(\'/html/body/div/ul/li/a/text()\')
print(html)
for i in html_data:
    print(i)
 
 #打印结果
<Element html at 0x138e4b8>
first item
second item
third item
fourth item
fifth item

打开读取html文件

#使用parse打开html的文件
html = etree.parse(\'test.html\')
html_data = html.xpath(\'//*\')<br>#打印是一个列表,需要遍历
print(html_data)
for i in html_data:
    print(i.text)
html = etree.parse(\'test.html\')
html_data = etree.tostring(html,pretty_print=True)
res = html_data.decode(\'utf-8\')
print(res)
 
打印:
<div>
     <ul>
         <li class=\"item-0\"><a href=\"link1.html\">first item</a></li>
         <li class=\"item-1\"><a href=\"link2.html\">second item</a></li>
         <li class=\"item-inactive\"><a href=\"link3.html\">third item</a></li>
         <li class=\"item-1\"><a href=\"link4.html\">fourth item</a></li>
         <li class=\"item-0\"><a href=\"link5.html\">fifth item</a></li>
     </ul>
</div>

打印指定路径下a标签的属性(可以通过遍历拿到某个属性的值,查找标签的内容)

html = etree.HTML(wb_data)
html_data = html.xpath(\'/html/body/div/ul/li/a/@href\')
for i in html_data:
    print(i)
 
打印:
link1.html
link2.html
link3.html
link4.html
link5.html

我们知道我们使用xpath拿到得都是一个个的ElementTree对象,所以如果需要查找内容的话,还需要遍历拿到数据的列表。

查到绝对路径下a标签属性等于link2.html的内容。

html = etree.HTML(wb_data)
html_data = html.xpath(\'/html/body/div/ul/li/a[@href=\"link2.html\"]/text()\')
print(html_data)
for i in html_data:
    print(i)
 
打印:
[\'second item\']
second item

上面我们找到全部都是绝对路径(每一个都是从根开始查找),下面我们查找相对路径,例如,查找所有li标签下的a标签内容。

html = etree.HTML(wb_data)
html_data = html.xpath(\'//li/a/text()\')
print(html_data)
for i in html_data:
    print(i)
 
打印:
[\'first item\', \'second item\', \'third item\', \'fourth item\', \'fifth item\']
first item
second item
third item
fourth item
fifth item

上面我们使用绝对路径,查找了所有a标签的属性等于href属性值,利用的是/—绝对路径,下面我们使用相对路径,查找一下l相对路径下li标签下的a标签下的href属性的值,注意,a标签后面需要双//。

html = etree.HTML(wb_data)
html_data = html.xpath(\'//li/a//@href\')
print(html_data)
for i in html_data:
    print(i)
 
打印:
[\'link1.html\', \'link2.html\', \'link3.html\', \'link4.html\', \'link5.html\']
link1.html
link2.html
link3.html
link4.html
link5.html

相对路径下跟绝对路径下查特定属性的方法类似,也可以说相同。

html = etree.HTML(wb_data)
html_data = html.xpath(\'//li/a[@href=\"link2.html\"]\')
print(html_data)
for i in html_data:
    print(i.text)
 
打印:
[<Element a at 0x216e468>]
second item

查找最后一个li标签里的a标签的href属性

html = etree.HTML(wb_data)
html_data = html.xpath(\'//li[last()]/a/text()\')
print(html_data)
for i in html_data:
    print(i)
 
打印:
[\'fifth item\']

查找倒数第二个li标签里的a标签的href属性

html = etree.HTML(wb_data)
html_data = html.xpath(\'//li[last()-1]/a/text()\')
print(html_data)
for i in html_data:
    print(i)
 
打印:
[\'fourth item\']
fourth item
版权声明

本文仅代表作者观点,不代表百度立场。
本文系作者授权百度百家发表,未经许可,不得转载。

热门文章
  • 机房智能化温湿度解决方式之POE供电以太网温湿度传感器

    机房智能化温湿度解决方式之POE供电以太网温湿度传感器
    机房智能化温湿度解决方式之POE供电以太网温湿度传感器 北京盈创力和电子科技有限公司 智能型TCP网口温湿度记录仪 北京IP网络温湿度记录仪厂家,北京盈创力和 北京智能型TCP网口温湿度记录仪IP网络温湿度记录仪是一种新型的基于TCP/IP协议双绞线以太网标准温湿度采集模块,利用它可以实现现场温度值、相对湿度值的采集,同时利用其自身的RJ45通信接口可以方便地和机房监控主机或交换机集线器进行联网。 工作于-40℃~85℃工业级带...
  • Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering

    Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering
    Problem Statement 我们考虑一个具有马尔可夫性质、非线性、非高斯的状态空间模型(State Space Model):对于一个时间序列上的观测结果{yt,t∈N}\\{ y_t , t \\in N \\}{yt​,t∈N},我们认为每个观测结果yty_tyt​的生成依赖于一个无法直接观察的隐变量xt∈{xt,t∈N}x_t \\in \\{x_t , t \\in N \\}xt​∈{xt​,t∈N},即:p(...
  • HTTP状态保持的原理

    HTTP状态保持的原理
    a)在用户登录之后,浏览器返回响应的时候会在响应中添加上cookieb)浏览器接收到cookie之后会自动保存c)当用户再次请求同一服务器中的其他网页的时候,浏览器会自动带上之前保存的cookied)服务接收到请求之后可以请 request 对象中取到cookie 判断当前用户是否登录  Http是无状态的,就是连接时数据互通,关闭后...
  • Hive 系统函数及示例

    Hive 系统函数及示例
    查看所有系统函数 show functions; 函数分类 内置函数【系统函数】 数学函数: floor、round、ceil、cos、log2等 字符串函数: length、reverse、trim、lower、get_json_object、repeat等 收集函数: size 转换函数: cast 日期函数: year、month、datediff、date、date_add等 条件函数: coalesce、case…w...
  • CSRF的原理和防范措施

    CSRF的原理和防范措施
    a)攻击原理:i.用户C访问正常网站A时进行登录,浏览器保存A的cookieii.用户C再访问攻击网站B,网站B上有某个隐藏的链接或者图片标签会自动请求网站A的URL地址,例如表单提交,传指定的参数iii.而攻击网站B在访问网站A的时候,浏览器会自动带上网站A的cookieiv.所以网站A在接收到请求之后可判断当前用户是登录状态,所以...
标签列表