http://www.ourunix.org/post/327.html

在python中解析XML文件也有Dom和Sax两种方式,这里先介绍如何是使用Dom解析XML,这一篇文章是Dom生成XML文件,下一篇文章再继续介绍Dom解析XML文件。

在生成XML文件中,我们主要使用下面的方法来完成。

主要方法

1、生成XML节点(node)

Python代码

createElement("node_name")

2、给节点添加属性值(Attribute)

Python代码

node.setAttribute("att_name", "arr_value")

3、节点的标签值(data)

Python代码

createTextNode("node_value")

其中第1、3点在创建完节点(节点值)之后,还需使用下面的方法添加到指点的节点的位置下面:

Python代码

prev_node.appendChild(cur_node)

这里的prev_node要添加节点的上一层节点,而cur_node即为当前要添加的节点了。

代码演示

下面用代码来演示下如何使用Dom来生成XML,这个是简单版本,如下:

Python代码

'''

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.ourunix.org")

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/HTML代码

<?xml version="1.0" encoding="utf-8"?>

<book_store name="newhua" website="http://www.ourunix.org">

<book1>

<name>hamlet</name>

<author>William Shakespeare</author>

</book1>

</book_store>

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

Python代码

'''

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.ourunix.org")

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/HTML代码

<?xml version="1.0" encoding="utf-8"?>

<book_store name="new hua" website="http://www.ourunix.org">

<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>

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

Python:Dom生成XML文件(写XML)的更多相关文章

  1. android-pull方式解析xml文件以及XML文件的序列化

    android解析XML ---------------------------基础要像磐石 在android平台上可以使用SAX.DOM和自带的Pull解析器解析xml文件,本文主要介绍使用pull ...

  2. xmlns:xsi ——是指xml文件遵守xml规范,xsi全名:xml schema instance

    http://blog.sina.com.cn/s/blog_4b6f8d150100nx3e.html http://blog.csdn.net/iaiti/article/details/4226 ...

  3. 使用Java解析XML文件或XML字符串的例子

    转: 使用Java解析XML文件或XML字符串的例子 2017年09月16日 11:36:18 inter_peng 阅读数:4561 标签: JavaXML-Parserdom4j 更多 个人分类: ...

  4. Android项目中的config.xml文件 “config.xml”

    Android应用程序需要保存一些配置时,可以将这些配置项放置到values/config.xml文件中. 实例分析: <?xml version="1.0" encodin ...

  5. 利用Python 脚本生成 .h5 文件 代码

    利用Python 脚本生成 .h5 文件 import os, json, argparse from threading import Thread from Queue import Queue ...

  6. Java生成XML文件与XML文件的写入

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6651643.html  既然能在代码中解析XML文档获取数据,当然也能通过代码动态生成XML文档了. 与解析X ...

  7. Android 生成xml文件及xml的解析

    1.生成xml文件的两种方式 (1)采用拼接的方式生成xml(不推荐使用) (2)利用XmlSerializer类生成xml文件 package com.example.lucky.test52xml ...

  8. PHP读xml、写xml(DOM方法)

    <?php /** * 读取的xml的格式 * <urlset> * <url> * <loc>http://www.51buy.com/0.html< ...

  9. 生成当前目录文件的xml描述

    需求场景:例如需要在当前目录下把相关文件组织成xml文件去描述.通常在组织项目中的升级文件时候可能会用到. 代码示例: using System; using System.Collections.G ...

随机推荐

  1. 【linux高级程序设计】(第九章)进程间通信-管道 2

    文件描述符重定向 cat<test01  :将输入重定向到test01文件 cat>test02<test01  :将标准正确输出重定向到test02文件,输入设备重定向到test0 ...

  2. Appium+python自动化10-AVD 模拟器【转载】

    前言 有些小伙伴没android手机,这时候可以在电脑上开个模拟器玩玩 一.模拟器配置 1.双击启动AVD Manager,进入配置界面

  3. J.U.C并发框架源码阅读(十)ConcurrentLinkedQueue

    基于版本jdk1.7.0_80 java.util.concurrent.ConcurrentLinkedQueue 代码如下 /* * ORACLE PROPRIETARY/CONFIDENTIAL ...

  4. Netty源码学习(六)ChannelPipeline

    0. ChannelPipeline简介 ChannelPipeline = Channel + Pipeline,也就是说首先它与Channel绑定,然后它是起到类似于管道的作用:字节流在Chann ...

  5. 51nod 1649.齐头并进-最短路(Dijkstra)

    1649 齐头并进 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题 在一个叫奥斯汀的城市,有n个小镇(从1到n编号),这些小镇通过 ...

  6. [CF232E]Quick Tortoise

    题目大意: 给你一个$n\times m(n,m\leq 500)$的格子,有一些是障碍物.从一个格子出发只能向下或向右走,有$q$组询问,每次询问从一个点是否能够到达另一个点. 思路: 分治. 两点 ...

  7. zlib stream

      官方帮助手册 http://www.zlib.net/manual.html   #include <stdlib.h> #include <string.h> #incl ...

  8. 九. 常用类库、向量与哈希3.Java语言包(java.lang)简介

    Java语言包(java.lang)定义了Java中的大多数基本类,由Java语言自动调用,不需要显示声明.该包中包含了Object类,Object类是整个类层次结构的根结点,同时还定义了基本数据类型 ...

  9. java读取配置文件常用的四种方式

    配置文件 放置在src下面 obj.properties className=com.store.order.dao.impl.OrderDaoImpl 方式一 @Test public void t ...

  10. [android]加载大量图片避免OOM

    原理是事先取得图片的长宽,直接读出缩略图. BitmapFactory.Options options = new BitmapFactory.Options(); options.inPreferr ...