Python - XML-Datei lesen (DOM-Beispiel)
In diesem Beispiel zeigen wir Ihnen, wie Sie eine XML-Datei lesen und ihre Werte über Pythonxml.dom.minidom
ausdrucken.
1. XML-Datei
Eine einfache XML-Datei, die später mit Pythonminidom
analysiert wird.
staff.xml
Mkyong Enterprise example 100,000 yflow 200,000 alex 20,000
2. DOM Beispiel 1
Ein einfaches Beispiel für 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))
Ausgabe
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 Beispiel 2
Noch einminidom
Beispiel.
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)))
Ausgabe
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