Python - чтение файла XML (пример DOM)
В этом примере мы покажем вам, как читать XML-файл и распечатывать его значения через Pythonxml.dom.minidom.
1. XML-файл
Простой XML-файл, позже проанализируйте его с помощью Pythonminidom.
staff.xml
Mkyong Enterprise example 100,000 yflow 200,000 alex 20,000
2. DOM, пример 1
Простой пример Pythonminidom.
dom-example.py
from xml.dom import minidom
doc = minidom.parse("staff.xml")
# doc.getElementsByTagName returns NodeList
name = doc.getElementsByTagName("name")[0]
print(name.firstChild.data)
staffs = doc.getElementsByTagName("staff")
for staff in staffs:
sid = staff.getAttribute("id")
nickname = staff.getElementsByTagName("nickname")[0]
salary = staff.getElementsByTagName("salary")[0]
print("id:%s, nickname:%s, salary:%s" %
(sid, nickname.firstChild.data, salary.firstChild.data))
Выход
Mkyong Enterprise id:1001, nickname:example, salary:100,000 id:1002, nickname:yflow, salary:200,000 id:1003, nickname:alex, salary:20,000
3. DOM, пример 2
Еще один примерminidom.
dom-example2.py
from xml.dom import minidom
doc = minidom.parse("staff.xml")
def getNodeText(node):
nodelist = node.childNodes
result = []
for node in nodelist:
if node.nodeType == node.TEXT_NODE:
result.append(node.data)
return ''.join(result)
name = doc.getElementsByTagName("name")[0]
print("Node Name : %s" % name.nodeName)
print("Node Value : %s \n" % getNodeText(name))
staffs = doc.getElementsByTagName("staff")
for staff in staffs:
sid = staff.getAttribute("id")
nickname = staff.getElementsByTagName("nickname")[0]
salary = staff.getElementsByTagName("salary")[0]
print("id:%s, nickname:%s, salary:%s" %
(sid, getNodeText(nickname), getNodeText(salary)))
Выход
Node Name : name Node Value : Mkyong Enterprise id:1001, nickname:example, salary:100,000 id:1002, nickname:yflow, salary:200,000 id:1003, nickname:alex, salary:20,000