创建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 ...
随机推荐
- EF Core MYSQL 生成表映射配置问题
Model表 public class Goods { public string ID { get; set; } public string CreatedBy { get; set; } pub ...
- 根据id查询所有子节点/父节点,mysql 以及ssm前后台处理流程
1.所示案例数据表结构设计如下所示: 2.案例数据如下所示: 3.mysql查询语句可以查询出父级目录信息: 注意:自己的数据表表名称,切记手动修改,字段名称(特别注意id,parent_id字段名称 ...
- Caused by: java.lang.ClassNotFoundException: backtype.storm.topology.IRichSpout
1:初次运行Strom程序出现如下所示的错误,贴一下,方便脑补,也希望帮助到看到的小伙伴: 错误如下所示,主要问题是刚开始使用maven获取jar包的时候需要写<scope>provide ...
- 【转】Android逆向入门流程
原文:https://www.jianshu.com/p/71fb7ccc05ff 0.写在前面 本文是笔者自学笔记,以破解某目标apk的方式进行学习,中间辅以原理性知识,方便面试需求. 参考文章的原 ...
- php处理IOS图片旋转
$picAddr = $url; $exif = exif_read_data($picAddr); $image = imagecreatefromjpeg($picAddr); if($exif[ ...
- scrapy中输出中文保存中文
1.json文件中文解码: #!/usr/bin/python #coding=utf-8 #author=dahu import json with open('huxiu.json','r') a ...
- 【Android】Android EditText 去除边框
[Android]Android EditText 去除边框 将EditText属性设置修改 android:background="@null" //////////////// ...
- zabbix通过自动发现tomcat应用端口监控连接数
192.168.10.98上 netstat -anp | wc -l netstat -anp|grep 8094 | grep ESTABLISHED | wc -l netstat -anp|g ...
- python3改版后的特征
1.原始数据类型和运算符 # 整数 3 # => 3 # 算术没有什么出乎意料的 1 + 1 # => 2 8 - 1 # => 7 10 * 2 # => 20 # 但是除法 ...
- lvs-nat 实验
1 ipvsadm集群服务管理工具使用 安装ipvsadm: yum install ipvsadm 参数: Ipvsadm -h : 获取帮助 -A 创建一个新的集群服务 -E 修 ...