Python - XMLファイルを読み込む(DOMの例)

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

4. プロジェクトのデモ