python 中 lxml 的 etree 标签解析
作者:autofelix 时间:2023-02-26 02:59:37
一、安装
pip install lxml
二、创建标签
from lxml import etree
root = etree.Element('root')
三、添加子节点
from lxml import etree
root = etree.Element('root')
span = etree.SubElement(root, 'span')
四、删除子节点
from lxml import etree
root = etree.Element('root')
span = etree.SubElement(root, 'span')
root.remove(span)
五、删除所有子节点
from lxml import etree
root = etree.Element('root')
root.clear()
六、操作子节点
from lxml import etree
root = etree.Element('root')
span = etree.SubElement(root, 'span')
# 获取标签数
len(root)
# 获取标签索引号,如果有多个相同标签的话,可以区分
root.index(span)
# 按位置插入
root.insert(0, etree.Element('p'))
# 尾部添加
root.append(etree.Element('strong'))
七、获取父节点
获取标签父节点的两种方法:
from lxml import etree
root = etree.Element('root')
span = etree.SubElement(root, 'span')
# 获取父节点方法一
span.getparent().tag
# 获取父节点方法二,用列表获取子节点,再获取父节点
root[0].getparent().tag
八、创建属性
from lxml import etree
root = etree.Element('root')
root.set('title', '这是一个root标签')
九、获取属性
获取属性的三种方法
from lxml import etree
root = etree.Element('root')
# 获取属性方法一
root.get('title')
# 获取属性方法二,参考字典的操作
root.keys(),root.values(),root.items()
# 获取属性方法三,直接拿到属性存放的字典
root.attrib
十、设置标签文本
添加文本和追加文本
from lxml import etree
root = etree.Element('root')
# 标签内添加文本
root.text='i am autofelix'
# 标签后追加文本
root.tail = 'i am autofelix'
十一、xpath方法
from lxml import etree
root = etree.Element('root')
word = root.xpath('//text()')
word[0].getparent().tag
十二、判断文本类型
from lxml import etree
root = etree.Element('root')
word = root.xpath('//text()')
# 是否是text文本
word.is_text
# 是否是tail文本
word.is_tail
十三、字符串解析
from lxml import etree
html = etree.fromstring('<root>autofelix</root>')
html.tag
etree.tostring(html)
十四、XML解析
from lxml import etree
html = etree.XML('<root>autofelix</root>')
html.tag
etree.tostring(html)
十五、去除XML中的空行
from lxml import etree
# 去除xml文件里的空行
parser= etree.XMLParser(remove_blank_text=True)
root = etree.XML('<root> auto felix </root>', parser)
print etree.tostring(root)
十六、HTML解析
HTML方法,如果没有<html>和<body>标签,会自动补上
from lxml import etree
html = etree.HTML('<root>autofelix</root>')
etree.tostring(html)
十七、搜索和定位
from lxml import etree
root = etree.XML('<root><a class="uname">i am autofelix<b/><c/><b/></a></root>')
# findall操作返回列表
root.findall('a')[0].text
# find操作就相当与找到了这个元素节点,返回匹配到的第一个元素
root.find('.//a').text
# 配合列表解析
[ b.text for b in root.findall('.//a') ]
# 根据属性查询
root.findall('.//a[@class]')[0].tag
来源:https://blog.51cto.com/autofelix/5150324
标签:python, lxml,etree,标签
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
JS本地刷新返回上一页代码
2023-08-06 13:59:57
文章内链(标签)的一个思路
2009-10-31 19:03:00
Python 3.x基础实战检查磁盘可用空间
2021-05-11 09:21:25
ASP读取XML实例 优酷专辑采集程序 雷锋版
2011-03-08 11:05:00
javascript闭包的秘密
2008-09-28 20:39:00
Python数据分析之 Matplotlib 折线图绘制
2023-12-05 02:18:13
![](https://img.aspxhome.com/file/2023/2/83902_0s.webp)
使用PyQt4 设置TextEdit背景的方法
2021-09-01 14:41:43
8个js表单验证函数
2007-10-28 19:19:00
十分钟搞定pandas(入门教程)
2023-08-09 01:00:15
![](https://img.aspxhome.com/file/2023/0/63950_0s.jpg)
Python获取"3年前的今天"的日期时间问题
2022-02-01 12:12:13
功能和外观都还不错的js版幻灯片效果
2007-08-05 12:20:00
asp中使用js的encodeURIComponent
2008-10-13 09:19:00
php常用字符串长度函数strlen()与mb_strlen()用法实例分析
2023-11-14 13:47:51
asp如何检测HTTP表头信息?
2010-06-28 18:20:00
用Python+OpenCV对比图像质量的几种方法
2022-06-28 10:57:59
![](https://img.aspxhome.com/file/2023/1/66821_0s.png)
Python实现求一个集合所有子集的示例
2022-09-01 20:56:51
网站重构 CSS样式表的优化技巧
2009-05-12 11:51:00
利用Anaconda完美解决Python 2与python 3的共存问题
2022-05-16 17:51:43
asp如何使用SMTP Service发送邮件?
2010-06-05 12:43:00
新浪微博文字渐隐效果
2011-04-29 12:33:00