创建xml文件、解析xml文件
1.创建XML文件:
import codecs import xml.dom.minidom
doc=xml.dom.minidom.Document() print doc
root=doc.createElement("booklist")
print u"添加的xml标签为",root.tagName
root.setAttribute("type","science and engineering")
value=root.getAttribute("type")
print u"root元素的'type'属性值为:",value
#添加第一本书:
book=doc.createElement("book")
book.setAttribute("category","math")
title=doc.createElement("title")
title.appendChild(doc.createTextNode("learning math"))
author=doc.createElement("author")
author.appendChild(doc.createTextNode(u"张三"))
pageNumber=doc.createElement("pageNumber")
pageNumber.appendChild(doc.createTextNode("561"))
book.appendChild(title)
book.appendChild(author)
book.appendChild(pageNumber)
root.appendChild(book)
doc.appendChild(root)
#添加第二本书:
book=doc.createElement("book")
book.setAttribute("category","python")
title=doc.createElement("title")
title.appendChild(doc.createTextNode("learning python"))
author=doc.createElement("author")
author.appendChild(doc.createTextNode(u"李四"))
pageNumber=doc.createElement("pageNumber")
pageNumber.appendChild(doc.createTextNode("600"))
book.appendChild(title)
book.appendChild(author)
book.appendChild(pageNumber)
root.appendChild(book)
print doc.toxml()
#写入文件保存
fp=codecs.open(r"e:\abc\book.xml","w","utf-8")
doc.writexml(fp,indent="",addindent="\t",newl="\n",encoding="utf-8") fp.close()

2.解析XML文件:
from xml.dom.minidom import parse
DOMTree=parse(r"e:\abc\book.xml") #解析成内存中的一棵文档树
print type(DOMTree)
#print u"xml文档内容:\n%s"%DOMTree.toxml()
booklist=DOMTree.documentElement #获取文档树的根 print booklist
#判断存在某属性并获取属性值
if booklist.hasAttribute("type"):
print u"booklist元素存在type属性"
print u"booklist元素的type属性值是:%s"%booklist.getAttribute("type")
else:
print u"booklist元素不存在type属性"
#获取节点元素
books=booklist.getElementsByTagName("book")
print type(books)
print books
print u"book节点的个数:",len(books)
print "*"*20
for book in books:
if book.hasChildNodes():
#获取所有子节点对象
print book.childNodes
#获取节点文本值
title=book.getElementsByTagName("title")
print "title is:",title[0].childNodes[0].data
else:
print u"不存在叶子节点"
创建xml文件、解析xml文件的更多相关文章
- python 解析XML python模块xml.dom解析xml实例代码
分享下python中使用模块xml.dom解析xml文件的实例代码,学习下python解析xml文件的方法. 原文转自:http://www.jbxue.com/article/16587.html ...
- dom4j组装xml 以及解析xml
dom4j组装xml 以及解析xml: 1.下载dom4j的jar包,地址:https://dom4j.github.io/ 2.java代码: package test; import java.i ...
- 7.数据本地化CCString,CCArray,CCDictionary,tinyxml2,写入UserDefault.xml文件,操作xml,解析xml
数据本地化 A CCUserDefault 系统会在默认路径cocos2d-x-2.2.3\projects\Hello\proj.win32\Debug.win32下生成一个名为UserDef ...
- Python—使用xml.sax解析xml文件
什么是sax? SAX是一种基于事件驱动的API. 利用SAX解析XML文档牵涉到两个部分:解析器和事件处理器. 解析器负责读取XML文档,并向事件处理器发送事件,如元素开始跟元素结束事件; 而事件处 ...
- android基础篇------------java基础(11)(文件解析xml and Json )
一:xml文件解析 首先看一下:我们要解析的内容: <?xml version="1.0" encoding="gbk" ?> - <book ...
- Dom生成Xml和解析Xml
xml这样的文件格式在非常多时候都是非常适合我们用来存取数据的,所以利用程序来生成xml文件和解析xml文件就显得比較重要了.在dom中是把每个元素都看做是一个节点Node的,全部页面上的属性.元素等 ...
- C#仪器数据文件解析-RTF文件
RTF格式文件大家并不陌生,但RTF文件的编码.解码却很难,因为RTF文件是富文本格式的,即文件中除了包含文本内容,还包含文本的格式信息,而这些信息并没有像后来的docx等采用XML来隔离格式和内容, ...
- C#仪器数据文件解析-Excel文件(xls、xlsx)
不少仪器工作站可以将数据导出为Excel文件,包括97-2003版本的xls文件和2007+的xlsx文件. 采集Excel文件相比采集pdf文件更容易.程序更健壮,毕竟Excel中数据有明确的行.列 ...
- C#仪器数据文件解析-Word文件(doc、docx)
不少仪器数据报告输出为Word格式文件,同Excel文件,Word文件doc和docx的存储格式是不同的,相应的解析Word文件的方式也类似,主要有以下方式: 1.通过MS Word应用程序的DCOM ...
- Python使用xml.dom解析xml
在菜鸟教程上找了个关于电影信息的xml类型的文档,用python内置的xml.dom来解析提取一下信息. 先复习一下xml概念: XML 指可扩展标记语言(EXtensible Markup Lang ...
随机推荐
- Android NDK开发调试
ndk-stack: https://developer.android.com/ndk/guides/ndk-stack?hl=zh-cn JNI开发: https://developer.andr ...
- vi不保存退出
To quit the vi editor without saving any changes you've made If you are currently in insert or appen ...
- Log4Net帮助类
工具类 using System; using System.Diagnostics; using log4net; namespace Trumgu_BI_PF.Util { public clas ...
- 令人疑惑的 std::remove 算法
摘自<Effective STL>第32条 remove的声明: template<class ForwardIterator, class T> ForwardIterato ...
- 【CF666E】Forensic Examination
题解: 熟练掌握了后缀自动机后大部分题目应该都比较容易想 首先对t建立广义后缀自动机 然后我们可以用线段树合并处理出每个点每个串出现的次数,然后求出最大值 匹配的时候比较巧妙 我们离线处理 对于同一个 ...
- Nginx代理实现内网主机访问公网服务
通过Nginx代理实现内网主机访问公网和接口服务 1.需求: m2.test.com为公司测试环境的微信测试域名,因为要调用微信服务接口需要访问外网,现通过Nginx代理现实此功能. 2.环境如下: ...
- nginx-fastcgi 反向代理
Nginx处理php页面 用fpm-server 基于fastcgi模块实现 Ngx_http_proxy_module 只能反代后端http server的主机 Ngx_fastcgi_prox ...
- BZOJ2287 【POJ Challenge】消失之物 动态规划 分治
原文链接http://www.cnblogs.com/zhouzhendong/p/8684027.html 题目传送门 - BZOJ2287 题意 有$n$个物品,第$i$个物品的体积为$w_i$. ...
- P1441 砝码称重 DFS回溯+DP
题目描述 现有n个砝码,重量分别为a1,a2,a3,……,an,在去掉m个砝码后,问最多能称量出多少不同的重量(不包括0). 请注意,砝码只能放在其中一边. 输入输出格式 输入格式: 输入文件weig ...
- LoadRunner中 host-mapping的Capture Level说明
lr录制后空白,那么就要弄明白lr中host-mapping的Capture Level选项socket level data.winnet level data.socket level andwi ...