Python – XMLファイルの読み取り(DOMの例)
この例では、Pythonxml.dom.minidom
を使用して、XMLファイルを読み取り、その値を出力する方法を示します。
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