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,标签
0
投稿

猜你喜欢

  • Python利用matplotlib.pyplot.boxplot()绘制箱型图实例代码

    2022-11-18 05:08:26
  • Java连接MySQL数据库增删改查的通用方法(推荐)

    2024-01-22 12:00:36
  • 模糊查询

    2024-01-21 09:23:30
  • 完美解决webstorm启动索引文件卡死的问题

    2022-04-05 05:52:29
  • Python实现读取txt文件中的数据并绘制出图形操作示例

    2021-07-21 17:01:15
  • 详解python实现多张多格式图片转PDF并打包成exe

    2022-06-16 15:43:38
  • Python获取协程返回值的四种方式详解

    2023-10-03 15:13:21
  • 浅谈Python中的可变对象和不可变对象

    2021-07-17 16:58:49
  • pyqt实现.ui文件批量转换为对应.py文件脚本

    2022-01-22 03:32:26
  • win10安装tensorflow-gpu1.8.0详细完整步骤

    2023-01-22 08:44:33
  • 纯JS实现动态时间显示代码

    2024-05-02 17:31:34
  • python pickle 和 shelve模块的用法

    2023-11-07 22:41:11
  • python调用并链接MATLAB脚本详解

    2021-12-11 07:16:42
  • python学生信息管理系统(完整版)

    2023-06-25 05:16:31
  • java使用正则表达式判断邮箱格式是否正确的方法

    2022-07-24 20:31:10
  • MySQL单表百万数据记录分页性能优化技巧

    2024-01-20 01:34:33
  • VB应用程序访问SQL Server的常用方法

    2009-01-21 14:28:00
  • 实例讲解如何利用crontab定时备份MySQL

    2009-01-04 13:06:00
  • 在sql查询中使用表变量

    2024-01-23 10:25:59
  • 仿dw8代码折叠功能的HTML编辑器

    2008-04-29 21:19:00
  • asp之家 网络编程 m.aspxhome.com