xml中俩种解析方式

两种解析方式

1、from xml.etree import ElementTree as ET

利用ElementTree模块下的xml方法可以把一个字符串类型的东西转换成Element类,从而利用Element类下面的方法

xml(字符串)解析方式只能读不能写

from xml.etree import ElementTree as ET

# 打开文件,读取XML内容
str_xml = open(‘xo.xml‘, ‘r‘).read()

# 将字符串解析成xml特殊对象,root代指xml文件的根节点
root = ET.XML(str_xml)
from xml.etree import ElementTree as ET
a=open("first_xml","r",encoding="utf-8").read()
print(type(a))
b=ET.XML(a)                  其中b为根节点                                #利用xml方法可以的到一个Element类
print(type(b))

<class ‘str‘>                    输入一个字符串类型的转成Element类<class ‘xml.etree.ElementTree.Element‘>
def XML(text, parser=None):
    """Parse XML document from string constant.

    This function can be used to embed "XML Literals" in Python code.

    *text* is a string containing XML data, *parser* is an
    optional parser instance, defaulting to the standard XMLParser.

    Returns an Element instance.

Element下面的方法:

1、  iter所查看的东西)返回所匹配到的元素的迭代器     用于找到某一类节点并去循环

  Return an iterator containing all the matching elements.

2、   tag  返回节点的标签名

3、   attrib 返回标签的属性

4、  find()找到第一个匹配到的对象并返回   只能找儿子不能找孙子

5、    txet 获取标签的内容

2、parse(文件名)打开文件并解析,相比于xml少了打开文件那一步

from xml.etree import ElementTree as ET

# 直接解析xml文件
tree = ET.parse("xo.xml")

# 获取xml文件的根节点
root = tree.getroot()      通过getroot获取根节点
from xml.etree import ElementTree as ET
a=ET.parse("first_xml")
print(a.getroot(),type(a))                    #解析成ElementTree类的对象

<Element ‘data‘ at 0x00000033D062F958> <class ‘xml.etree.ElementTree.ElementTree‘>
def parse(source, parser=None):
    """Parse XML document into element tree.

    *source* is a filename or file object containing XML data,
    *parser* is an optional parser instance defaulting to XMLParser.

    Return an ElementTree instance.

    """
    tree = ElementTree()
    tree.parse(source, parser)
    return tree

ElementTree下面的方法:

1、  getroot()     获取xml文件的根节点    与xml不同(通过xml()直接获取根节点,而parse()还的再通过getroot获取根节点)

2、  根节点.tag       获取节点的标签(这里与xml不同的是先利用getroot()得到根节点再tag)

3、  根节点.attrib    获取节点的属性(原理同上)

4、  text               获取标签的内容

5、  a.write(文件名)写入文件

from xml.etree import ElementTree as ET
a=ET.parse("first_xml")
b=a.getroot()
for i in b.iter("year"):
    new_year=int(i.text)+1
    i.text=str(new_year)
a.write("first_xml")

6、  标签名.set("k1","k2")    为标签添加属性

7、  del 标签名 attrib["k1"]  删除标签的属性,如果标签名无属性,删除报错

3、创建一个XML文档

from xml.etree import ElementTree as ET
a=ET.Element("aaa")                 #创建根节点
b=ET.Element("bbb",{"k1":"k2"})    #创建子节点
c=ET.Element("ccc",{"k2":"k3"})
d=ET.Element("ddd",{"k3":"k4"})

a.append(b)
b.append(c)
c.append(d)
et = ET.ElementTree(a)      #生成文档对象
et.write("test.xml", encoding="utf-8", xml_declaration=True, short_empty_elements=False)
时间: 2024-10-15 06:42:51

xml中俩种解析方式的相关文章

Xml的三种解析方式

XML的三种解析方式:DOM.SAX.PULL解析 废话不说上代码: package com.minimax.xmlparsedemo; import java.io.InputStream; import java.util.List; import android.os.Bundle; import android.app.Activity; import android.content.res.AssetManager; import android.util.Log; import an

xml的两种解析方式

xml解析是日常项目中用到比較多的技能.不管是配置參数或者数据都能够保存在xml文件里.同一时候也能够将xml作为数据传输的一种格式.本文将介绍两种基本解析方式:xml字符串解析和xml文件解析. xml字符串解析 package com.discover.parse; import java.util.Iterator; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Documen

XML解析——Java中XML的四种解析方式

 XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四种:1.DOM解析:2.SAX解析:3.JDOM解析:4.DOM4J解析.其中前两种属于基础方法,是官方提供的平台无关的解析方式:后两种属于扩展方法,它们是在基础的方法上扩展出来的,只适用于java平台. 针对以下XML文件,会对四种方式进行详细描述: 1 <?xml version="1.

黑马程序员——XML解析---java中XML的四种解析方式

------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四种:1.DOM解析:2.SAX解析:3.JDOM解析:4.DOM4J解析.其中前两种属于基础方法,是官方提供的平台无关的解析方式:后两种属于扩展方法,它们是在基础的方法上扩展出来的,只适用于jav

Java中XML的四种解析方式(二)

三.JDOM解析 特征: 1.仅使用具体类,而不使用接口. 2.API大量使用了Collections类. 1 import org.jdom2.Attribute; 2 import org.jdom2.Document; 3 import org.jdom2.Element; 4 import org.jdom2.JDOMException; 5 import org.jdom2.input.*; 6 import java.io.*; 7 import java.util.ArrayLis

XML的四种解析方式

基础方法: DOM.SAX DOM:与平台无关的官方解析方式 SAX:基于事件驱动的解析方式 扩展方法:JDOM.DOM4J(在基础的方法上扩展的,只有Java能够使用的解析方式) DOM: 一次性解析完毕! import java.io.FileOutputStream; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.tran

XML的两种解析方式逐行解析(SAX解析)节点解析(DOM解析);

SAX逐行解析 SAX:SimpleAPIfor XML.基于事件驱动的解析方式,逐行解析数据.(采用协议回调机制) NSXMLParser是iOS自带的XML解析类.采用SAX方式解析数据 解析过程由NSXMLParserDelegate协议方法回调 解析过程:开始标签->取值->结束标签->取值 DOM解析 DOM:DocumentObjectModel(文档对象模型).解析时需要将XML文件整体读入,并且将XML结构化成树状,使用时再通过树状结构读取相关数据 GDataXMLNod

XML的两种解析方式,Dom4j and SAX parse

Dom4j and Sax difference. Dom4j 解析的速度慢,而且消耗内存,因为在解析之前要先把文件放到内存中.并采用基于对象的模型解析 有以下几点: 1. Dom4J parse loads the entire XML file into memory before parsing. 2. It uses Object based Model for parsing XML. 3. High memory usage - as it loads the file to mem

Qt中三种解析xml的方式

在下面的随笔中,我会根据xml的结构,给出Qt中解析这个xml的三种方式的代码.虽然,这个代码时通过调用Qt的函数实现的,但是,很多开源的C++解析xml的库,甚至很多其他语言解析xml的库,都和下面三种解析xml采用相同的原理,所以就算你不是学习qt,也可以大致参看一下代码,对三种解析方式有一种大致的感觉. 先给出xml如下: <?xml version="1.0" encoding="utf-8"?> <school> <teach