需求
在實(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ì)您有幫助就好】元
