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. 13.OpenStack常用命令

    常用的命令 使用trove create创建数据库 trove create name --size= --databases DBNAME \ --users USER:PASSWORD --dat ...

  2. JavaWeb响应下载(包含工具类)

    纸上得来终觉浅,绝知此事要躬行!今天博主分享是关于javaweb的响应(response)下载 以下是我的Demo: 页面我就粘主要部分的代码 <a href = "${pageCon ...

  3. ZOJ3874 Permutation Graph(NTT&&cdq分治)

    最近在看几道整体二分还有cdq分治的东西,突然间想起前几个礼拜的ZOJ题,然后看了一下代码,经过了一些深思熟虑之后,发现自己终于看懂了,下面就用别人的代码来剖析一下整个解题的思路吧,具体的内容我再看看 ...

  4. Delphi存取图像完整解决方案

    http://blog.sina.com.cn/s/blog_693cf1cf0100plkq.html 对于涉及图像数据的数据库应用程序,图像数据的存取技术是一个关键.由于缺少技术文档及DEMO例程 ...

  5. codeforces-723D

    题目连接:http://codeforces.com/contest/723/problem/D D. Lakes in Berland time limit per test 2 seconds m ...

  6. 如何理解java反射?

    一.反射基本概念 反射之中包含了一个"反"的概念,所以要想解释反射就必须先从"正"开始解释,一般而言,当用户使用一个类的时候,应该先知道这个类,而后通过这个类产 ...

  7. 【bzoj2393】【Cirno的完美算数教室】容斥原理的剪枝应用

    (上不了p站我要死了,侵权度娘背锅) 在用容斥定理时,常常会用到dfs的形式,如果枚举完所有的情况可能会超时,其剪枝的优化很是重要. Description ~Cirno发现了一种baka数,这种数呢 ...

  8. JSONP 安全攻防技术(JSON劫持、 XSS漏洞)

    关于 JSONP JSONP 全称是 JSON with Padding ,是基于 JSON 格式的为解决跨域请求资源而产生的解决方案.他实现的基本原理是利用了 HTML 里 <script&g ...

  9. 【转】matlab 字符串处理函数

    原文地址 matlab 字符串处理函数 % 字符串处理 a='  a';b='b  b';c='cccc';m='' % 获取字符串长度 length(a)     % 连接两个字符串,每个字符串最右 ...

  10. 【Linux】CentOS7 上使用yum安装和卸载软件【yum安装wine举例】

    关于yum的相关解释,请 man yum 自行查看. 配置常用源:http://www.cnblogs.com/sxdcgaq8080/p/7516186.html yum的使用类似于在windows ...