Python中使用dom模块生成XML文件示例

在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", "http://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="http://www.jb51.net"> 
    <book1> 
        <name>hamlet</name> 
        <author>William Shakespeare</author> 
    </book1> 
</book_store>

当然一旦你掌握了这些基本方法之后,我们可以用一个类来更好的完成,这个类我们称之为XMLGenerator,代码如下:

代码如下:

'''
Created on 2012-8-28 
 
@author:  walfred
@module: domxml.wXMLbyDom 
@description:
''' 
import xml.dom.minidom as Dom 
 
class XMLGenerator: 
    def __init__(self, xml_name): 
        self.doc = Dom.Document() 
        self.xml_name = xml_name 
 
    def createNode(self, node_name): 
        return self.doc.createElement(node_name) 
 
    def addNode(self, node, prev_node = None): 
        cur_node = node 
        if prev_node is not None: 
            prev_node.appendChild(cur_node) 
        else: 
            self.doc.appendChild(cur_node) 
        return cur_node 
 
    def setNodeAttr(self, node, att_name, value): 
        cur_node = node 
        cur_node.setAttribute(att_name, value) 
 
    def setNodeValue(self, cur_node, value): 
        node_data = self.doc.createTextNode(value) 
        cur_node.appendChild(node_data) 
 
    def genXml(self): 
        f = open(self.xml_name, "w") 
        f.write(self.doc.toprettyxml(indent = "\t", newl = "\n", encoding = "utf-8")) 
        f.close() 
 
if __name__ == "__main__": 
    myXMLGenerator = XMLGenerator("book_store.xml") 
 
    #xml root node 
    node_book_store = myXMLGenerator.createNode("book_store") 
    myXMLGenerator.setNodeAttr(node_book_store, "name", "new hua") 
    myXMLGenerator.setNodeAttr(node_book_store, "website", "http://www.jb51.net") 
    myXMLGenerator.addNode(node = node_book_store) 
 
    #book01 
    node_book_01 = myXMLGenerator.createNode("book") 
 
    node_book_01_name = myXMLGenerator.createNode("name") 
    myXMLGenerator.setNodeValue(node_book_01_name, "Hamlet") 
    myXMLGenerator.addNode(node_book_01_name, node_book_01) 
 
    node_book_01_author = myXMLGenerator.createNode("author") 
    myXMLGenerator.setNodeValue(node_book_01_author, "William Shakespeare") 
    myXMLGenerator.addNode(node_book_01_author, node_book_01) 
 
    node_book_01_price = myXMLGenerator.createNode("price") 
    myXMLGenerator.setNodeValue(node_book_01_price, "$20") 
    myXMLGenerator.addNode(node_book_01_price, node_book_01) 
 
    node_book_01_grade = myXMLGenerator.createNode("grade") 
    myXMLGenerator.setNodeValue(node_book_01_grade, "good") 
    myXMLGenerator.addNode(node_book_01_grade, node_book_01) 
 
    myXMLGenerator.addNode(node_book_01, node_book_store) 
 
    #book 02 
    node_book_02 = myXMLGenerator.createNode("book") 
 
    node_book_02_name = myXMLGenerator.createNode("name") 
    myXMLGenerator.setNodeValue(node_book_02_name, "shuihu") 
    myXMLGenerator.addNode(node_book_02_name, node_book_02) 
 
    node_book_02_author = myXMLGenerator.createNode("author") 
    myXMLGenerator.setNodeValue(node_book_02_author, "naian shi") 
    myXMLGenerator.addNode(node_book_02_author, node_book_02) 
 
    node_book_02_price = myXMLGenerator.createNode("price") 
    myXMLGenerator.setNodeValue(node_book_02_price, "$200") 
    myXMLGenerator.addNode(node_book_02_price, node_book_02) 
 
    node_book_02_grade = myXMLGenerator.createNode("grade") 
    myXMLGenerator.setNodeValue(node_book_02_grade, "good") 
    myXMLGenerator.addNode(node_book_02_grade, node_book_02) 
 
    myXMLGenerator.addNode(node_book_02, node_book_store) 
 
    #gen 
    myXMLGenerator.genXml()

同样这个方法会在本目录下生成一个book_store.xml文件,如下:

代码如下:

<?xml version="1.0" encoding="utf-8"?> 
<book_store name="new hua" website="http://www.jb51.net"> 
    <book> 
        <name>Hamlet</name> 
        <author>William Shakespeare</author> 
        <price>$20</price> 
        <grade>good</grade> 
    </book> 
    <book> 
        <name>shuihu</name> 
        <author>naian shi</author> 
        <price>$200</price> 
        <grade>good</grade> 
    </book> 
</book_store>

这个版本算一个稍微高级的版本,但由于时间有限还很显得粗糙,读者可以发挥出更好的。

(0)

相关推荐

  • python操作xml文件详细介绍

    关于python读取xml文章很多,但大多文章都是贴一个xml文件,然后再贴个处理文件的代码.这样并不利于初学者的学习,希望这篇文章可以更通俗易懂的教如何使用python 来读取xml 文件. 一.什么是xml? xml即可扩展标记语言,它可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言. abc.xml 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> <catalo

  • python处理xml文件的方法小结

    本文实例讲述了python处理xml文件的方法.分享给大家供大家参考,具体如下: 前一段时间因为工作的需要,学习了一点用Python处理xml文件的方法,现在贴出来,供大家参考. xml文件是按节点一层一层来叠加的,最顶层的是根节点.比如说: <sys:String x:Key="STR_License_WithoutLicense">Sorry, you are not authorized.</sys:String> 其中sys:String为节点名字,x:

  • python写入xml文件的方法

    本文实例讲述了python写入xml文件的方法.分享给大家供大家参考.具体分析如下: 本范例通过xml模块对xml文件进行写入操作 from xml.dom.minidom import Document doc = Document() people = doc.createElement("people") doc.appendChild(people) aperson = doc.createElement("person") people.appendChi

  • python操作xml文件示例

    复制代码 代码如下: def get_seed_data(filename):dom = minidom.parse(filename)root = dom.documentElementsystem_nodes = root.getElementsByTagName("system")k = 0seed_list = []for system_node in system_nodes:    #print system_node.nodeName+' id='+system_node

  • Python使用MYSQLDB实现从数据库中导出XML文件的方法

    本文实例讲述了Python使用MYSQLDB实现从数据库中导出XML文件的方法.分享给大家供大家参考.具体分析如下: 这里需要给前端以xml格式提供一些数据,这些数据在目前的数据库中已经存在. 如果使用django返回xml数据的话,需要包装下头信息: 复制代码 代码如下: r = HttpResponse(str_xml) r.mimetype = "text/xml" r['Content-Type'] = "application/xml" 另外,使用grou

  • Python创建xml文件示例

    本文实例讲述了Python创建xml文件的方法.分享给大家供大家参考,具体如下: 这是一个使用ElementTree有关类库,生成xml文件的例子 # *-* coding=utf-8 from xml.etree.ElementTree import ElementTree from xml.etree.ElementTree import Element from xml.etree.ElementTree import SubElement from xml.etree.ElementTr

  • python写xml文件的操作实例

    本文实例讲述了python写xml文件的操作的方法,分享给大家供大家参考.具体方法如下: 要生成的xml文件格式如下: <?xml version="1.0" ?> <!--Simple xml document__chapter 8--> <book> <title> sample xml thing </title> <author> <name> <first> ma </fir

  • python解析xml文件实例分析

    本文实例讲述了python解析xml文件的方法.分享给大家供大家参考.具体如下: python解析xml非常方便.在dive into python中也有讲解. 如果xml的结构如下: <?xml version="1.0" encoding="utf-8"?> <books> <book> <author>zoer</author> <title>think in java</title

  • Python 解析XML文件

    Python文件: 复制代码 代码如下: #parsexml.py #本例子参考自python联机文档,做了适当改动和添加 import xml.parsers.expat #控制打印缩进 level = 0 #获取某节点名称及属性值集合 def start_element(name, attrs): global level print ' '*level, 'Start element:', name, attrs level = level + 1 #获取某节点结束名称 def end_e

  • 实例Python处理XML文件的方法

    需求 有一个表,里面数据量比较大,每天一更新,其字段可以通过xml配置文件进行配置,即,可能每次建表的字段不一样. 上游跑时会根据配置从源文件中提取,到入库这一步需要根据配置进行建表. 解决 写了一个简单的xml,配置需要字段及类型 上游读取到对应的数据 入库这一步,先把原表删除,根据配置建新表 XML文件 <?xml version="1.0" encoding="UTF-8"?> <!-- 表名 ,数据库名 可灵活配置插入哪个库哪个表 --&g

  • python解析xml文件实例分享

    复制代码 代码如下: def get_area_list(self):        """获取地域省份和城市名称字典"""        page = urllib2.urlopen(self.xml_url).read()        area_list = {}        root = ElementTree.fromstring(page)        #读取xml格式文本        for onep in root:    

  • python解析xml文件操作实例

    本文实例讲述了python解析xml文件操作的实现方法.分享给大家供大家参考.具体方法如下: xml文件内容如下: <?xml version="1.0" ?> <!--Simple xml document__chapter 8--> <book> <title> sample xml thing </title> <author> <name> <first> ma </first

随机推荐