创新互联www.cdcxhl.cn八线动态BGP香港云服务器提供商,新人活动买多久送多久,划算不套路!
成都创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站建设、成都做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的灵丘网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!这篇文章主要介绍python支不支持用xml读写,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
由于Python对XML读写有多种库,本文以xml.etree import ElementTree为例。
解析
from xml.etree import ElementTree as ET ############ 解析方式一 ############ # 打开文件,读取XML内容 str_xml = open('xo.xml', 'r').read() # 利用ElementTree.XML将字符串解析成xml对象,root代指xml文件的根节点 root = ET.XML(str_xml)
操作XML
XML遍历
from xml.etree import ElementTree as ET ############ 解析方式二 ############ # 直接解析xml文件 tree = ET.parse("xo.xml") # 获取xml文件的根节点 root = tree.getroot() ### 操作 # 顶层标签 print(root.tag) # 遍历XML文档的第二层 for child in root: # 第二层节点的标签名称和标签属性 print(child.tag, child.attrib) # 遍历XML文档的第三层 for i in child: # 第二层节点的标签名称和内容 print(i.tag,i.text) # 遍历XML中所有的year节点 for node in root.iter('year'): # 节点的标签名称和内容 print(node.tag, node.text) #修改:将year节点中的内容自增一 new_year = int(node.text) + 1 node.text = str(new_year) # 设置属性 node.set('name', 'alex') node.set('age', '18') # 删除属性 del node.attrib['name'] # 遍历data下的所有country节点 for country in root.findall('country'): # 获取每一个country节点下rank节点的内容 rank = int(country.find('rank').text) if rank > 50: # 删除指定country节点 root.remove(country) ############ 保存文件 ############ tree = ET.ElementTree(root) tree.write("new.xml", encoding='utf-8') ## 可能需要的调整格式 from xml.dom import minidom def xmlwrite(root,filepath) rough_string = ET.tostring(root, 'utf-8') reparsed = minidom.parseString(rough_string) raw_str = reparsed.toprettyxml(indent='',newl="") output = open(filepath,'w+',encoding='utf-8') output.write(' \n ') output.write(raw_str) output.close()
每个节点都具有以上方法,通过root可以操作整个xml文件。
以上是python支不支持用xml读写的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联-成都网站建设公司行业资讯频道!