在Python中解析XML文件也有Dom和Sax两种方式,这里先介绍如何是使用Dom解析XML,这一篇文章是Dom生成XML文件,下一篇文章再继续介绍Dom解析XML文件。
在生成XML文件中,我们主要使用下面的方法来完成。
主要方法
1、生成XML节点(node)
 代码如下:
createElement("node_name")
2、给节点添加属性值(Attribute)
 代码如下:
node.setAttribute("att_name", "arr_value")
3、节点的标签值(data)
 代码如下:
createTextNode("node_value")
其中第1、3点在创建完节点(节点值)之后,还需使用下面的方法添加到指点的节点的位置下面:
 代码如下:
prev_node.appendChild(cur_node)
这里的prev_node要添加节点的上一层节点,而cur_node即为当前要添加的节点了。
代码演示
下面用代码来演示下如何使用Dom来生成XML,这个是简单版本,如下:
 代码如下:
'''
Created on 2012-8-28  
 
@author:  walfred 
@module: domxml.genXML  
@description: 
'''  
import xml.dom.minidom as Dom  
 
if __name__ == "__main__":  
    doc = Dom.Document()  
    root_node = doc.createElement("book_store")  
    root_node.setAttribute("name", "newhua")  
    root_node.setAttribute("website", "//www.jb51.net")  
    doc.appendChild(root_node)  
 
    book_node = doc.createElement("book1")  
 
    book_name_node = doc.createElement("name")  
    book_name_value = doc.createTextNode("hamlet")  
    book_name_node.appendChild(book_name_value)  
    book_node.appendChild(book_name_node)  
 
    book_author_node = doc.createElement("author")  
    book_author_value = doc.createTextNode("William Shakespeare")  
    book_author_node.appendChild(book_author_value)  
    book_node.appendChild(book_author_node)  
 
    root_node.appendChild(book_node)  
 
    f = open("book_store.xml", "w")  
    f.write(doc.toprettyxml(indent = "/t", newl = "/n", encoding = "utf-8"))  
    f.close()
这个代码将在当前目录下生成一个book_store.xml文件,我把它也贴在下面:
 代码如下:
<?xml version="1.0" encoding="utf-8"?>  
<book_store name="newhua" website="//www.jb51.net">  
    <book1>  
        <name>hamlet</name>              
新闻热点
疑难解答