一、DOM寫XML文件
#導入minidom
from xml.dom import minidom
# 1.創建DOM樹對象
dom=minidom.Document()
# 2.創建根節點。每次都要用DOM對象來創建任何節點。
root_node=dom.createElement('root')
# 3.用DOM對象添加根節點
dom.appendChild(root_node)
# 用DOM對象創建元素子節點
book_node=dom.createElement('book')
# 用父節點對象添加元素子節點
root_node.appendChild(book_node)
# 設置該節點的屬性
book_node.setAttribute('price','199')
name_node=dom.createElement('name')
root_node.appendChild(name_node)
# 也用DOM創建文本節點,把文本節點(文字內容)看成子節點
name_text=dom.createTextNode('計算機程序設計語言 第1版')
# 用添加了文本的節點對象(看成文本節點的父節點)添加文本節點
name_node.appendChild(name_text)
# 每一個結點對象(包括dom對象本身)都有輸出XML內容的方法,如:toxml()--字符串, toprettyxml()--美化樹形格式。
try:
with open('dom_write.xml','w',encoding='UTF-8') as fh:
# 4.writexml()第一個參數是目標文件對象,第二個參數是根節點的縮進格式,第三個參數是其他子節點的縮進格式,
# 第四個參數制定了換行格式,第五個參數制定了xml內容的編碼。
dom.writexml(fh,indent='',addindent='\t',newl='\n',encoding='UTF-8')
print('寫入xml OK!')
except Exception as err:
print('錯誤信息:{0}'.format(err))
二、DOM解析XML文件
from xml.dom import minidom
with open('dom_write.xml','r',encoding='utf8') as fh:
# parse()獲取DOM對象
dom=minidom.parse(fh)
# 獲取根節點
root=dom.documentElement
# 節點名稱
print(root.nodeName)
# 節點類型:'ELEMENT_NODE',元素節點; 'TEXT_NODE',文本節點; 'ATTRIBUTE_NODE',屬性節點
print(root.nodeType)
# 獲取某個節點下所有子節點,是個列表
print(root.childNodes)
# 通過dom對象或根元素,再根據標簽名獲取元素節點,是個列表
book=root.getElementsByTagName('book')[0]
# 獲取節點屬性
print(book.getAttribute('price'))
# 獲取某個元素節點的文本內容,先獲取子文本節點,然后通過“data”屬性獲取文本內容
name=root.getElementsByTagName('name')[0]
name_text_node=name.childNodes[0]
print(name_text_node.data)
# 獲取某節點的父節點
print(name.parentNode.nodeName)
三. ElemenTree解析xml
import xml.etree.ElementTree as ET
tree = ET.parse("country.xml")
root = tree.getroot()
print(root.tag, ":", root.attrib) # 打印根元素的tag和屬性
# 遍歷xml文檔的第二層
for child in root:
# 第二層節點的標簽名稱和屬性
print(child.tag,":", child.attrib)
# 遍歷xml文檔的第三層
for children in child:
# 第三層節點的標簽名稱和屬性
print(children.tag, ":", children.attrib)
2)ElementTree提供的方法
find(match) # 查找第一個匹配的子元素, match可以時tag或是xpaht路徑
findall(match) # 返回所有匹配的子元素列表
findtext(match, default=None) #
iter(tag=None) # 以當前元素為根節點 創建樹迭代器,如果tag不為None,則以tag進行過濾
iterfind(match)
# 遍歷所有的counry標簽
for country in root.findall("country"):
# 查找country標簽下的第一個rank標簽
rank = country.find("rank").text
# 獲取country標簽的name屬性
name = country.get("name")
print(name, rank)
import xml.etree.ElementTree as ET
tree = ET.parse("output.xml")
root = tree.getroot()
for rank in root.iter("rank"):
# attrib為屬性字典
# 刪除對應的屬性updated
del rank.attrib['updated']
ET.dump(root)
結: 關于class xml.etree.ElementTree.Element 屬性相關
attrib 為包含元素屬性的字典
keys() 返回元素屬性名稱列表
items() 返回(name,value)列表
get(key, default=None) 獲取屬性
set(key, value) # 跟新/添加 屬性
del xxx.attrib[key] # 刪除對應的屬性
- 節點/元素 相關
刪除子元素remove()
import xml.etree.ElementTree as ET
tree = ET.parse("country.xml")
root = tree.getroot()
# 刪除rank大于50的國家
for country in root.iter("country"):
rank = int(country.find("rank").text)
if rank > 50:
# remove()方法 刪除子元素
root.remove(country)
ET.dump(root)
3.添加子元素
import xml.etree.ElementTree as ET
tree = ET.parse("country.xml")
root = tree.getroot()
country = root[0]
last_ele = country[len(list(country))-1]
last_ele.tail = '\n\t\t'
# 創建新的元素, tag為test_append
elem1 = ET.Element("test_append")
elem1.text = "elem 1"
# elem.tail = '\n\t'
country.append(elem1)
# SubElement() 其實內部調用的時append()
elem2 = ET.SubElement(country, "test_subelement")
elem2.text = "elem 2"
# extend()
elem3 = ET.Element("test_extend")
elem3.text = "elem 3"
elem4 = ET.Element("test_extend")
elem4.text = "elem 4"
country.extend([elem3, elem4])
# insert()
elem5 = ET.Element("test_insert")
elem5.text = "elem 5"
country.insert(5, elem5)
ET.dump(country)
4.創建xml文檔
想創建root Element,然后創建SubElement,最后將root element傳入ElementTree(element),創建tree,調用tree.write()方法寫入文件
對于創建元素的3個方法: 使用ET.Element、Element對象的makeelement()方法以及ET.SubElement
import xml.etree.ElementTree as ET
def subElement(root, tag, text):
ele = ET.SubElement(root, tag)
ele.text = text
ele.tail = '\n'
root = ET.Element("note")
to = root.makeelement("to", {})
to.text = "peter"
to.tail = '\n'
root.append(to)
subElement(root, "from", "marry")
subElement(root, "heading", "Reminder")
subElement(root, "body", "Don't forget the meeting!")
tree = ET.ElementTree(root)
tree.write("note.xml", encoding="utf-8", xml_declaration=True)
由于原生保存的XML時默認無縮進,如果想要設置縮進的話, 需要修改保存方式
import xml.etree.ElementTree as ET
from xml.dom import minidom
def subElement(root, tag, text):
ele = ET.SubElement(root, tag)
ele.text = text
def saveXML(root, filename, indent="\t", newl="\n", encoding="utf-8"):
rawText = ET.tostring(root)
dom = minidom.parseString(rawText)
with open(filename, 'w') as f:
dom.writexml(f, "", indent, newl, encoding)
root = ET.Element("note")
to = root.makeelement("to", {})
to.text = "peter"
root.append(to)
subElement(root, "from", "marry")
subElement(root, "heading", "Reminder")
subElement(root, "body", "Don't forget the meeting!")
# 保存xml文件
saveXML(root, "note.xml")