python库——Lxml

本文介绍Lxml模块,一种用于Python的高效XML和HTML解析库。文章详细解释了如何使用Lxml处理不规范的HTML,通过CSS选择器进行元素选择,并对比了其与正则表达式的性能。Lxml不仅速度快,而且易于使用,适用于多种场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Lxml模块使用C语言编写,解析速度比BeautifulSoup要快。用于处理Python语言中的XML和HTML。
可直接命令行pip install lxml安装。

Lxml爬虫使用

  1. 将有可能不合法的HTML解析为统一格式
>>>import lxml.html
>>>broken_html = '<ul class=shop><li>Price<li>Number</ul>'
>>>tree = lxml.html.fromstring(broken_html) #解析HTML
>>>fixed_html = lxml.html.tostring(tree,pretty_print=True)
>>>print(fixed_html)
<ul class="shop">
 <li>Price</li>
 <li>Number</li>
</ul>
  1. 使用CSS选择器选择元素
    lxml有几种不同的方法选择元素,CSS选择器更加简洁并且可以在解析动态内容时得以复用。
    css选择器的安装:pip install cssselect
    例(爬取中国天气网天气):
import lxml.html
import urllib.request

url = 'http://www.weather.com.cn/weather/101020100.shtml'
#模拟成浏览器
headers = ("User-Agent","Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36 SE 2.X MetaSr 1.0")
opener = urllib.request.build_opener()
opener.addheaders = [headers]
html = urllib.request.urlopen(url).read()
tree = lxml.html.fromstring(html)
td = tree.cssselect('p.tem')[0]
wea=td.text_content()
print(wea)

CSS选择器语法

  1. 选择所有标签:*
  2. 选择< a>标签:a (<>中字母任意,根据实际情况)
  3. 选择所有class="link"的元素:.link
  4. 选择class="link"的< a>标签:a.link
  5. 选择id="home"的< a>标签:a#home
  6. 选择父元素为< a>标签的所有< b>子标签:a > b
  7. 选择< a>标签内部所有< b>标签:a b
  8. 选择title属性为"Home"的所有< a>标签:a[title=Home]

性能分析

Lxml的性能和正则表达式几乎一样好,而且使用简单。相比之下此方法既快速又健壮,适合在各种场景使用。

部分内容参照自《用python写网络爬虫》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叶柖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值