python中lxml的使用注意点
- 更新时间:2021-06-19 08:18:04
- 编辑:宁奇玮
本站精选了一篇相关的编程文章,网友弓涵煦根据主题投稿了本篇教程内容,涉及到Python相关内容,已被838网友关注,相关难点技巧可以阅读下方的电子资料。
参考资料
- Python Cookbook PDF 电子书 / 29.4 MB / 比斯利 推荐度:
- Selenium 2自动化测试实战:基于Python语言 PDF 电子书 / 44 MB / 虫师 推荐度:
- 【Python标准库之字符串处理库、文件及目录操作、时间日期】知识点结构图 / 1.69 MB / 码小辫 推荐度:
- 《基于ArcGIS的Python编程秘笈(第2版)》配套资源 配套资源 / 142.37 MB / [美]Eric Pimpler 派普勒 推荐度:
- 精通Python设计模式 PDF 电子书 / 11.8 MB / Sakis Kasampalis 推荐度:
正文内容
今天在网上看到《python中lxml的使用注意点》,感觉写的不错,改了一下错误代码,为了方便大家的阅读。
(推荐操作系统:windows7系统、Python 3.9.1、DELL G3电脑。)
1、使用注意
(1)lxml 能够修正 HTML 代码,但是可能会改错了,解决方法:
使用etree.tostring观察修改之后的html的样子,根据修改之后的html字符串写xpath
(2)提取页面数据的思路
先分组,取到一个包含分组标签的列表
遍历,取其中每一组进行数据的提取,不会造成数据的对应错乱
(3)lxml 能够接受bytes和str的字符串
2、实例
from lxml import etree text = ''' <div> <ul> <li><a href="link1.html">first item</a></li> <li><a href="link2.html">second item</a></li> <li><a href="link3.html">third item</a></li> <li><a href="link4.html">fourth item</a></li> <li><a href="link5.html">fifth item</a> </ul> </div> ''' html = etree.HTML(text) print(html) # <Element html at 0x1f1007c9d08> print(etree.tostring(html).decode()) # 获取 class 为 item-1 li 下的 a 的 href ret1 = html.xpath('//li[@class="item-1"]/a/@href') print(ret1) # 获取 class 为 item-1 li 下的文本 ret2 = html.xpath("//li[@class='item-1']/a/text()") print(ret2) # 把 url 和 文本组成字典 # 如果其中一个获取失败或者没有数据,则url 和 title 就不是原来对应的结果 for i in ret1: item = {} item['url'] = i item['title'] = ret2[ret1.index(i)] print(item) # 改进 ret3 = html.xpath('//li[@class="item-1"]') for i in ret3: item = {} item['url'] = i.xpath('./a/@href')[0] if len(i.xpath('./a/@href')) else None # ./a/@href 表示当前节点下的 item['title'] = i.xpath('./a/text()')[0] if len(i.xpath('./a/text()')) else None print(item)
以上就是python中lxml的使用注意点,希望能对大家有所帮助。更多Python学习指路:
相关教程
-
pygame实现简易飞机大战
这篇文章主要为大家详细介绍了pygame实现简易飞机大战,python版飞机大战,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
发布时间:2019-06-03
-
Python 把序列转换为元组的函数tuple方法
今天小编就为大家分享一篇Python 把序列转换为元组的函数tuple方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
发布时间:2019-09-08