需求
在實(shí)際應(yīng)用中,需要對(duì)xml配置文件進(jìn)行實(shí)時(shí)修改,
1.增加、刪除 某些節(jié)點(diǎn)
2.增加,刪除,修改某個(gè)節(jié)點(diǎn)下的某些屬性
3.增加,刪除,修改某些節(jié)點(diǎn)的文本
使用xml文檔
實(shí)現(xiàn)思想
使用ElementTree,先將文件讀入,解析成樹(shù),之后,根據(jù)路徑,可以定位到樹(shù)的每個(gè)節(jié)點(diǎn),再對(duì)節(jié)點(diǎn)進(jìn)行修改,最后直接將其輸出
實(shí)現(xiàn)代碼
#!/usr/bin/python
# -*- coding=utf-8 -*-
# author : wklken@yeah.net
# date: 2012-05-25
# version: 0.1
from xml.etree.ElementTree import ElementTree,Element
def read_xml(in_path):
'''讀取并解析xml文件
in_path: xml路徑
return: ElementTree'''
tree = ElementTree()
tree.parse(in_path)
return tree
def write_xml(tree, out_path):
'''將xml文件寫(xiě)出
tree: xml樹(shù)
out_path: 寫(xiě)出路徑'''
tree.write(out_path, encoding="utf-8",xml_declaration=True)
def if_match(node, kv_map):
'''判斷某個(gè)節(jié)點(diǎn)是否包含所有傳入?yún)?shù)屬性
node: 節(jié)點(diǎn)
kv_map: 屬性及屬性值組成的map'''
for key in kv_map:
if node.get(key) != kv_map.get(key):
return False
return True
#---------------search -----
def find_nodes(tree, path):
'''查找某個(gè)路徑匹配的所有節(jié)點(diǎn)
tree: xml樹(shù)
path: 節(jié)點(diǎn)路徑'''
return tree.findall(path)
def get_node_by_keyvalue(nodelist, kv_map):
'''根據(jù)屬性及屬性值定位符合的節(jié)點(diǎn),返回節(jié)點(diǎn)
nodelist: 節(jié)點(diǎn)列表
kv_map: 匹配屬性及屬性值map'''
result_nodes = []
for node in nodelist:
if if_match(node, kv_map):
result_nodes.append(node)
return result_nodes
#---------------change -----
def change_node_properties(nodelist, kv_map, is_delete=False):
'''修改/增加 /刪除 節(jié)點(diǎn)的屬性及屬性值
nodelist: 節(jié)點(diǎn)列表
kv_map:屬性及屬性值map'''
for node in nodelist:
for key in kv_map:
if is_delete:
if key in node.attrib:
del node.attrib[key]
else:
node.set(key, kv_map.get(key))
def change_node_text(nodelist, text, is_add=False, is_delete=False):
'''改變/增加/刪除一個(gè)節(jié)點(diǎn)的文本
nodelist:節(jié)點(diǎn)列表
text : 更新后的文本'''
for node in nodelist:
if is_add:
node.text += text
elif is_delete:
node.text = ""
else:
node.text = text
def create_node(tag, property_map, content):
'''新造一個(gè)節(jié)點(diǎn)
tag:節(jié)點(diǎn)標(biāo)簽
property_map:屬性及屬性值map
content: 節(jié)點(diǎn)閉合標(biāo)簽里的文本內(nèi)容
return 新節(jié)點(diǎn)'''
element = Element(tag, property_map)
element.text = content
return element
def add_child_node(nodelist, element):
'''給一個(gè)節(jié)點(diǎn)添加子節(jié)點(diǎn)
nodelist: 節(jié)點(diǎn)列表
element: 子節(jié)點(diǎn)'''
for node in nodelist:
node.append(element)
def del_node_by_tagkeyvalue(nodelist, tag, kv_map):
'''同過(guò)屬性及屬性值定位一個(gè)節(jié)點(diǎn),并刪除之
nodelist: 父節(jié)點(diǎn)列表
tag:子節(jié)點(diǎn)標(biāo)簽
kv_map: 屬性及屬性值列表'''
for parent_node in nodelist:
children = parent_node.getchildren()
for child in children:
if child.tag == tag and if_match(child, kv_map):
parent_node.remove(child)
if __name__ == "__main__":
#1. 讀取xml文件
tree = read_xml("./test.xml")
#2. 屬性修改
#A. 找到父節(jié)點(diǎn)
nodes = find_nodes(tree, "processers/processer")
#B. 通過(guò)屬性準(zhǔn)確定位子節(jié)點(diǎn)
result_nodes = get_node_by_keyvalue(nodes, {"name":"BProcesser"})
#C. 修改節(jié)點(diǎn)屬性
change_node_properties(result_nodes, {"age": "1"})
#D. 刪除節(jié)點(diǎn)屬性
change_node_properties(result_nodes, {"value":""}, True)
#3. 節(jié)點(diǎn)修改
#A.新建節(jié)點(diǎn)
a = create_node("person", {"age":"15","money":"200000"}, "this is the firest content")
#B.插入到父節(jié)點(diǎn)之下
add_child_node(result_nodes, a)
#4. 刪除節(jié)點(diǎn)
#定位父節(jié)點(diǎn)
del_parent_nodes = find_nodes(tree, "processers/services/service")
#準(zhǔn)確定位子節(jié)點(diǎn)并刪除之
target_del_node = del_node_by_tagkeyvalue(del_parent_nodes, "chain", {"sequency" : "chain1"})
#5. 修改節(jié)點(diǎn)文本
#定位節(jié)點(diǎn)
text_nodes = get_node_by_keyvalue(find_nodes(tree, "processers/services/service/chain"), {"sequency":"chain3"})
change_node_text(text_nodes, "new text")
#6. 輸出到結(jié)果文件
write_xml(tree, "./out.xml")
修改后的結(jié)果
this is the firest content
this is the firest content
new text
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元

