python xml文件解析 及生成xml文件
#解析一个database的xml文件 """
<databaselist type="database config">
<database>
<host>localhost</host>
<username>root</username>
<password>11111</password>
<datasename>wulaoshi</datasename>
</database>
</databaselist>
""" #解析xml文件
domtree=parse('d:\\pylianxi\\data.xml') #获取根节点
datalist=domtree.documentElement d={}
#获取标签为database的子节点
database=datalist.getElementsByTagName('database') #database的子节点轮询,过滤掉textNode节点,取出文本值
for i in database[0].childNodes[1::2]:
tag=i.tagName
d[tag]=i.childNodes[0].data #childNodes 获取的是一个列表,通过childNodes[0]获取具体对象 print('database:',d)
2、手动写一个xml文件
#写xml from xml.dom.minidom import * #创建一个文档对象
doc=Document() #创建一个根节点
root=doc.createElement('managers') #根节点添加属性
root.setAttribute('company','中体彩')
print(root.getAttribute('company')) #根节点加入到tree
doc.appendChild(root) #创建二级节点
company=doc.createElement('gloryroad')
name=doc.createElement('name')
name.appendChild(doc.createTextNode('公司名称')) #添加文本节点 #创建一个带着文本节点的子节点
ceo=doc.createElement('ceo')
ceo.appendChild(doc.createTextNode('吴总')) #<ceo>吴总</ceo> company.appendChild(name) #name加入到company
company.appendChild(ceo)
root.appendChild(company)#company加入到根节点 print(ceo.tagName) print(doc.toxml()) #存成xml文件
fp=open('d:\\pylianxi\\test.xml','w',encoding='utf-8')
doc.writexml(fp,indent='',addindent='\t',newl='\n',encoding='utf-8')
fp.close()
3、通过字典数据 存成xml文件
from xml.dom.minidom import Document
#在内存中创建一个空的文档
doc = Document() #创建一个根节点Managers对象
root = doc.createElement('Managers') #设置根节点的属性
root.setAttribute('company', '哈哈科技')
root.setAttribute('address', '科技软件园') #将根节点添加到文档对象中
doc.appendChild(root) managerList = [{'name' : 'joy', 'age' : 27, 'sex' : '女'},
{'name' : 'tom', 'age' : 30, 'sex' : '男'},
{'name' : 'ruby', 'age' : 29, 'sex' : '女'} ] for i in managerList :
nodeManager = doc.createElement('Manager')
for j in i: nodeName = doc.createElement(j)
#给叶子节点name设置一个文本节点,用于显示文本内容
nodeName.appendChild(doc.createTextNode(str(i[j]))) #将各叶子节点添加到父节点Manager中,
nodeManager.appendChild(nodeName) #最后将Manager添加到根节点Managers中
root.appendChild(nodeManager) #开始写xml文档
fp = open('d:\\pylianxi\\company11.xml', 'w',encoding='utf-8')
doc.writexml(fp, indent='', addindent='\t', newl='\n', encoding="utf-8")
fp.close()
4、使用etree的方式解析xml文件
#etree xml from xml.etree import ElementTree as ET
'''
直接解析XML文件并获得根节点
tree = ET.parse(xmlFilePath)
root = tree.getroot()
解析字符串
root = ET.fromstring(fp.read())
'''
tree=ET.ElementTree(file='d:\\pylianxi\\movies.xml') root=tree.getroot() #打印根节点的标签及属性字典
print(root.tag)
print(root.attrib) #获取子节点movie的标签及属性字典
for i in root:
print (i.tag)
print ("********", i.attrib) print ("*"*50)
print (root[0].tag)
print (root[0].text) #“打印的内容为一个回车”
print (root[0][0].tag) #第一个movie节点的第一个子标签type
print (root[0][0].text) print ("*"*50)
for i in tree.iter(): #递归遍历所有子元素
print (i.tag, i.attrib,i.text) print ("*"*50)
for elem in tree.iterfind('movie/type'):#或者这种方式./movie/type查找movie下一级节点中的所有type标签,类似xpath查找
print (elem.tag, elem.text) print ("*"*50)
print(list(tree.iter(tag='stars')))
for elem in tree.iter(tag='stars'):#在整个树中查找标签为stars的元素
print (elem.tag, elem.text) print ("*"*50)
for elem in tree.iterfind('*[@title="Ishtar"]'): #或者movie[@title="Ishtar"] 在下一级节点查找属性为title="Ishtar"的元素
print (elem.tag, elem.attrib) print ("-"*50)
root = tree.getroot() #获取第一级movie元素
print ("root:",root[0].tag ) #打印第一级movie元素的标签,为movie
print ("subnode:",root[0][0].tag) #打印第一级movie元素下的第一个子元素标签type
print ("subnode:",root[0][1].tag ) #打印第一级movie元素下的第二个子元素标签format
print ("subnode:",root[0][2].tag ) #打印第一级movie元素下的第三个子元素标签year
print ("subnode:",root[0][3].tag ) #打印第一级movie元素下的第四个子元素标签rating
print ("subnode:",root[0][4].tag ) del root[0][4] #删除第一级movie元素下的第五个子元素
del root[0][3] #删除第一级movie元素下的第四个子元素
del root[0][2] #删除第一级movie元素下的第三个子元素
del root[0][1] #删除第一级movie元素下的第二个子元素 del root[3] #删除第四个movie元素
del root[2] #删除第三个movie元素 for i in root:
print(i.tag,i.attrib)
for j in i:
print('******',j.tag,j.text)
#tree.write("d:\\movies.xml") #将变更的xml文件写入到文件中
5、etree的方式生成xml
#etree 生成一个xml a = ET.Element('elem') #生成一个节点elem,没有文本节点
aa = ET.SubElement(a, 'type') #生成一个字节点下的子节点child1
aa.text = "a的type子节点" #在子节点上添加文本节点
aa2 = ET.SubElement(a, 'name') #生成一个字节点下的子节点child2
aa2.text='a的name子节点' b = ET.Element('elem_b') #生成一个节点elem_b,没有文本节点
b.set('company','科技公司')
bb=ET.SubElement(b,'type')
bb.text='bb的type子节点'
bb2=ET.SubElement(b,'name')
bb2.text='bb的name子节点' root = ET.Element('root') #生成一个节点root
root.extend((a, b)) #将a、b两个变量存储的节点elem和elem1添加到root节点下
tree = ET.ElementTree(root) #生成节点树
root[0].set('foo', 'bar') #设定第一个子元素的属性foo,值为bar tree.write("d:\\pylianxi\\test.xml",encoding='utf-8') #将xml文件内容写入到文本文件中,文件格式并不是很漂亮
python xml文件解析 及生成xml文件的更多相关文章
- 使用Pull解析器生成XML文件和读取xml文件
有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...
- 使用Pull解析器生成XML文件
有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...
- SAX解析和生成XML文档
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本人声明.否则将追究法律责任. 作者: 永恒の_☆ 地址: http://blog.csdn.net/chenghui031 ...
- maven中使用dom4j解析、生成XML的简易方法
此片文章主要写一些关于如何在maven工程中使用dom4j来解析或生成XML的建议方法,实际可使用的写法不仅限于如下所写的样例代码.此处进攻快速入手和提供思路使用. 首先配置pom.xml中的依赖的包 ...
- 【转载并整理】JAVA解析或生成xml的四种方法
参考文章 1:http://blog.csdn.net/clemontine/article/details/53011362 2:http://www.jb51.net/article/98456. ...
- Dom4j解析、生成Xml
1以下代码未Xml的解析和生成代码 <?xml version="1.0" encoding="UTF-8"?> <users> < ...
- vim保存文件时,生成.un~文件
在用vim保存文件时,文件夹下生成.un~文件 怎么删除这些文件呢 在网上搜索的答案: http://stackoverflow.com/questions/15660669/what-is-a-un ...
- 【Linux开发】【DSP开发】利用CCS6.1生成out文件的同时生成bin文件
[Linux开发][DSP开发]利用CCS6.1生成out文件的同时生成bin文件 标签:[DSP开发] [Linux开发] 尝试在windows上安装的CCS6.1开发AM4378-Linux下的应 ...
- DEX文件解析--6、dex文件字段和方法定义解析
一.前言 前几篇文章链接: DEX文件解析---1.dex文件头解析 DEX文件解析---2.Dex文件checksum(校验和)解析 DEX文件解析--3. ...
随机推荐
- 【ARTS】01_46_左耳听风-201900923~201900929
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- [转帖]Hive 快速入门(全面)
Hive 快速入门(全面) 2018-07-30 16:11:56 琅琊山二当家 阅读数 4343更多 分类专栏: hadoop 大数据 转载: https://www.codercto.com/ ...
- C之指针加减运算
法则:1.指针减指针,语法正确,结果得一个整型值,表示两数值之间的对象类型的空间距离,而不是对象之间的字节数差值 2.指针加指针,语法错误, 3.指针加整形值,语法正确,表示后移N个空间单位 ...
- 题解 CF1216C 【White Sheet】
虽然也很水,但这道还是比前两道难多了... 题目大意:给你三个位于同一平面直角坐标系的矩形,询问你后两个是否完全覆盖了前一个 首先,最直观的想法应该是,把第一个矩形内部每个整数点检查一下,看看是否位于 ...
- 剑指offer41:所有和为S的连续正数序列,例如,有多少种连续的正数序列的和为100
1 题目描述 小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和,他马上就写出了正确答案是100.但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数).没多久 ...
- HCIA SWITCHING&ROUTTING 笔记——第一章 TCP/IP基础知识(2)
视频地址:https://ilearningx.huawei.com/courses/course-v1:HuaweiX+EBGTC00000336+Self-paced/courseware/abb ...
- git出现Invalid path
今天换了电脑,我直接把整个仓库从电脑A复制到了电脑B,包括仓库下面的 .git 文件夹. 修改代码后我执行了一下 git add . 出现了一个报错 fatal: Invalid path 'D:/S ...
- 百人研发团队的难题:研发管理、绩效考核、组织文化和OKR
分享一个公司规模近200,研发占一半的创业公司 Worktile 在研发团队管理方面的玩法,仅供百人左右研发团队参考~ 什么是研发团队?简单的说,你熟悉的那帮穿格子衬衫,以程序员为核心组成的团队,就是 ...
- MLP神经网络实例--手写识别
1.导入MNIST数据集 直接使用fetch_mldata会报错,错误信息是python3.7把fetch_mldata方法移除了,所以需要单独下载数据集从这个网站上下载数据集: https://gi ...
- 前端开发 Vue -4promise解读2
https://www.runoob.com/vue2/vue-tutorial.html promise promise是什么? 1.主要用于异步计算 2.可以将异步操作队列化,按照期望的顺序执 ...