一、安装
pip install lxml
二、创建标签
from lxml import etreeroot = ('root')
三、添加子节点
from lxml import etreeroot = ('root')span = (root, 'span')
四、删除子节点
from lxml import etreeroot = ('root')span = (root, 'span')(span)
五、删除所有子节点
from lxml import etreeroot = ('root')()
六、操作子节点
from lxml import etreeroot = ('root')span = (root, 'span')# 获取标签数len(root)# 获取标签索引号,如果有多个相同标签的话,可以区分(span)# 按位置插入(0, ('p'))# 尾部添加(('strong'))
七、获取父节点
获取标签父节点的两种方法
from lxml import etreeroot = ('root')span = (root, 'span')# 获取父节点方法一().tag# 获取父节点方法二,用列表获取子节点,再获取父节点root[0].getparent().tag
八、创建属性
from lxml import etreeroot = ('root')('title', '这是一个root标签')
九、获取属性
获取属性的三种方法
from lxml import etreeroot = ('root')# 获取属性方法一('title')# 获取属性方法二,参考字典的操作(),(),()# 获取属性方法三,直接拿到属性存放的字典
十、设置标签文本
添加文本和追加文本
from lxml import etreeroot = ('root')# 标签内添加文本='i am autofelix'# 标签后追加文本 = 'i am autofelix'
十一、xpath方法
from lxml import etreeroot = ('root')word = ('//text()')word[0].getparent().tag
十二、判断文本类型
from lxml import etreeroot = ('root')word = ('//text()')# 是否是text文本word.is_text# 是否是tail文本word.is_tail
十三、字符串解析
from lxml import etreehtml = ('<root>autofelix</root>')(html)
十四、XML解析
from lxml import etreehtml = ('<root>autofelix</root>')(html)
十五、去除XML中的空行
from lxml import etree# 去除xml文件里的空行parser= (remove_blank_text=True)root = ('<root> auto felix </root>', parser)print (root)
十六、HTML解析
HTML方法,如果没有<html>和<body>标签,会自动补上
from lxml import etreehtml = ('<root>autofelix</root>')(html)
十七、搜索和定位
from lxml import etreeroot = ('<root><a class="uname">i am autofelix<b/><c/><b/></a></root>')# findall操作返回列表('a')[0].text# find操作就相当与找到了这个元素节点,返回匹配到的第一个元素('.//a').text# 配合列表解析[ for 吉林*培训学校 b in ('.//a') ]# 根据属性查询('.//a[@class]')[0].tag