为方便遍历子节点,lxml将节点list的操作尽可能的与python处理list的方式一样保持一致
创建XML
from lxml import etree
root = etree.Element("root") #创建根节点
root.append(etree.Element("child1")) #创建子节点child1
child2 = etree.SubElement(root, "child2") #创建子节点child2
child3 = etree.SubElement(root, "child3") #创建子节点child3
具体的xml文件结构如下:
<root>
<child1></child1>
<child2></child2>
<child3></child3>
</root>
获取当前节点指定索引处子节点
child = root[0]
print(child.tag) #输出:child1
获取当前节点子节点个数
print(len(root)) #输出:3
获取节点在父节点中的索引
print(root.index(root[1])) #输出:1
子节点遍历
children = list(root)
for child in children:
print(child.tag)
#或
for child in root:
print(child.tag)
子节点插入
root.insert(0, etree.Element("child0"))
节点List操作
start = root[:1]
end = root[-1:]
print(start[0].tag) #输出:child0
print(end[0].tag) #输出:child3
包含子节点判断
#不推荐:
if root:
print("The root element has children")
#推荐: 该种方式更能让人读懂是用来判断节点是否包含子节点的
if len(root):
print("The root element has children")
父节点判断
print(root is root[0].getparent()) #输出:True
相邻节点判断
print(root[0] is root[1].getprevious()) #输出:True
print(root[1] is root[0].getnext()) #输出:True
节点判断
print(etree.iselement(root)) #输出:True
root11=''
print(etree.iselement(root11)) #输出:False,因为root11只是变量
子节点移动
for child in root:
print(child.tag)
'''输出:
child0
child1
child2
child3
'''
root[0] = root[-1] #child3是移动到了index为0的位置,它覆盖了child1
for child in root:
print(child.tag)
'''输出:
child3
child1
child2
'''
子节点拷贝
如果要将元素复制到lxml.etree中的其他位置,请考虑使用python标准库中的copy模块创建一个独立的深度复制
from lxml import etree
from copy import deepcopy
root = etree.Element("root") #创建根节点
root.append(etree.Element("child1")) #创建子节点child1
child2 = etree.SubElement(root, "child2") #创建子节点child2
child3 = etree.SubElement(root, "child3") #创建子节点child3
element = etree.Element("neu")
element.append(deepcopy(root[1]))
print(element[0].tag) #输出:child2
print([ c.tag for c in root ]) #输出:['child1', 'child2', 'child3'],原root节点下的子节点没有变化
element01 = etree.Element("neu01")
element01.append(root[1])
print(element01[0].tag) #输出:child2
print([ c.tag for c in root ]) #输出:['child1', 'child3'],原root节点下的子节点有变化,child2不见了
213

被折叠的 条评论
为什么被折叠?



