python中e库是干什么的_Python 标准库之 xml.etree

简介

Element类型是一种灵活的容器对象,用于在内存中存储结构化数据。

[注意]xml.etree.ElementTree模块在应对恶意结构数据时显得并不安全。

每个element对象都具有以下属性:

1. tag:string对象,表示数据代表的种类。

2. attrib:dictionary对象,表示附有的属性。

3. text:string对象,表示element的内容。

4. tail:string对象,表示element闭合之后的尾迹。

5. 若干子元素(child elements)。

texttail

1 2 3 4

创建元素的方法有Element或者SubElement(),前者称作元素的构建函数(constructor),用以构建任一独存的元素;后者称作元素的制造函数(factory function),用以制造某一元素的子元素。

有了一串元素之后,使用ElementTree类来将其打包,把一串元素转换为xml文件或者从xml文件中解析出来。

若想加快速度,可以使用C语言编译的API xml.etree.cElementTree。

导入ElementTree

在使用xml.etree.ElementTree时,一般都按如下导入:

try:

importxml.etree.cElementTree as ET

exceptImportError:

import xml.etree.ElementTree as ET

XML是中结构化数据形式,在ET中使用ElementTree代表整个XML文档,并视其为一棵树,Element代表这个文档树中的单个节点。

ET对象具有多种方法从不同来源导入数据,如下:

#从硬盘的xml文件读取数据

importxml.etree.ElementTree as ET

tree = ET.parse('country_data.xml') #载入数据

root =tree.getroot() #获取根节点

#从字符串读取数据

root = ET.fromstring(country_data_as_string)

[注意]fromstring()是直接获取string对象中的根节点,因此以上root其实是一个Element。

作为一个Element对象,本身是具有子元素,因此可以直接对Element进行迭代取值:

>>> for child inroot:

... printchild.tag, child.attrib

...

country {'name': 'Liechtenstein'}

country {'name': 'Singapore'}

country {'name': 'Panama'}

或者直接使用索引寻找子节点:

>>> root[0][1].text

'2008'

Element中的遍历与查询

Element.iter(tag=None):遍历该Element所有后代,也可以指定tag进行遍历寻找。

Element.findall(path):查找当前元素下tag或path能够匹配的直系节点。

Element.find(path):查找当前元素下tag或path能够匹配的首个直系节点。

Element.text: 获取当前元素的text值。

Element.get(key, default=None):获取元素指定key对应的属性值,如果没有该属性,则返回default值。

Element对象

class xml.etree.ElementTree.Element(tag, attrib={}, **extra)

tag:string,元素代表的数据种类。

text:string,元素的内容。

tail:string,元素的尾形。

attrib:dictionary,元素的属性字典。

#针对属性的操作

clear():清空元素的后代、属性、text和tail也设置为None。

get(key, default=None):获取key对应的属性值,如该属性不存在则返回default值。

items():根据属性字典返回一个列表,列表元素为(key, value)。

keys():返回包含所有元素属性键的列表。

set(key, value):设置新的属性键与值。

#针对后代的操作

append(subelement):添加直系子元素。

extend(subelements):增加一串元素对象作为子元素。#python2.7新特性

find(match):寻找第一个匹配子元素,匹配对象可以为tag或path。

findall(match):寻找所有匹配子元素,匹配对象可以为tag或path。

findtext(match):寻找第一个匹配子元素,返回其text值。匹配对象可以为tag或path。

insert(index, element):在指定位置插入子元素。

iter(tag=None):生成遍历当前元素所有后代或者给定tag的后代的迭代器。#python2.7新特性

iterfind(match):根据tag或path查找所有的后代。

itertext():遍历所有后代并返回text值。

remove(subelement):删除子元素。

ElementTree对象

class xml.etree.ElementTree.ElementTree(element=None, file=None)

element如果给定,则为新的ElementTree的根节点。

_setroot(element):用给定的element替换当前的根节点。慎用。

# 以下方法与Element类中同名方法近似,区别在于它们指定以根节点作为操作对象。

find(match)

findall(match)

findtext(match, default=None)

getroot():获取根节点.

iter(tag=None)

iterfind(match)

parse(source, parser=None):装载xml对象,source可以为文件名或文件类型对象.

write(file, encoding="us-ascii", xml_declaration=None, default_namespace=None,method="xml")

模块方法

xml.etree.ElementTree.Comment(text=None)创建一个特别的element,通过标准序列化使其代表了一个comment。comment可以为bytestring或unicode。xml.etree.ElementTree.dump(elem)生成一个element tree,通过sys.stdout输出,elem可以是元素树或单个元素。这个方法最好只用于debug。xml.etree.ElementTree.fromstring(text)text是一个包含XML数据的字符串,与XML()方法类似,返回一个Element实例。xml.etree.ElementTree.fromstringlist(sequence, parser=None)从字符串的序列对象中解析xml文档。缺省parser为XMLParser,返回Element实例。

New in version 2.7.xml.etree.ElementTree.iselement(element)检查是否是一个element对象。xml.etree.ElementTree.iterparse(source, events=None, parser=None)将文件或包含xml数据的文件对象递增解析为element tree,并且报告进度。events是一个汇报列表,如果忽略,将只有end事件会汇报出来。

注意,iterparse()只会在看见开始标签的">"符号时才会抛出start事件,因此届时属性是已经定义了,但是text和tail属性在那时还没有定义,同样子元素也没有定义,因此他们可能不能被显示出来。如果你想要完整的元素,请查找end事件。xml.etree.ElementTree.parse(source, parser=None)将一个文件或者字符串解析为element tree。xml.etree.ElementTree.ProcessingInstruction(target, text=None)这个方法会创建一个特别的element,该element被序列化为一个xml处理命令。xml.etree.ElementTree.register_namespace(prefix, uri)注册命名空间前缀。这个注册是全局有效,任何已经给出的前缀或者命名空间uri的映射关系会被删除。

New in version 2.7.xml.etree.ElementTree.SubElement(parent, tag, attrib={}, **extra)子元素工厂,创建一个Element实例并追加到已知的节点。xml.etree.ElementTree.tostring(element, encoding="us-ascii", method="xml")生成一个字符串来表示表示xml的element,包括所有子元素。element是Element实例,method为"xml","html","text"。返回包含了xml数据的字符串。xml.etree.ElementTree.tostringlist(element, encoding="us-ascii", method="xml")生成一个字符串来表示表示xml的element,包括所有子元素。element是Element实例,method为"xml","html","text"。返回包含了xml数据的字符串列表。

New in version 2.7.xml.etree.ElementTree.XML(text, parser=None)从一个字符串常量中解析出xml片段。返回Element实例。xml.etree.ElementTree.XMLID(text, parser=None)从字符串常量解析出xml片段,同时返回一个字典,用以映射element的id到其自身。

实例

xml

<?xml version="1.0" encoding="utf-8"?>

导购码接口测试

dgm.boweixin.com

80

[]

account

1

2

userId34

user_id

01001

登陆

POST

/Login

{"appStatus":{"errorCode":0,"message":"操作成功"},

"content":[{"user_sex":0,"fk_user_city":440300,

"user_id":30,"nickname":"18576759587",

"user_phone":"18576759587",

"head_picture":"http:\/\/dgm.boweixin.com\/",

"has_finance":1,

"user_state":1

}]

}

user_id

0

account

5

6

userId

7

8

user_id

10012

登陆1

POST1

/Login1

{"appStatus":{"errorCode":0,"message":"操作成功"},

"content":[{"user_sex":0,"fk_user_city":440300,

"user_id":30,"nickname":"18576759587",

"user_phone":"18576759587",

"head_picture":"http:\/\/dgm.boweixin.com\/",

"has_finance":1,

"user_state":1

}]

}

0

0

代码解析

from xml.etree import ElementTree as ET

def getXML(xml):

"""

"""

tree = ET.parse(xml)

root = tree.getroot()

i_base = {}

interfaceName = []

i_base["title"] = root.find("title").text

i_base["host"] = root.find("host").text

i_base["port"] = root.find("port").text

i_base["No"] = root.find("No").text

interfaceName.append(i_base)

for elem in root.findall("InterfaceList"):

i_app = {}

i_app["id"] = elem.find('id').text

i_app["name"] = elem.find('name').text

i_app["method"] = elem.find('method').text

i_app["url"] = elem.find('url').text

i_app["hope"] = elem.find('hope').text

i_app["login"] = elem.find('login').text

i_app["isList"] = elem.find('isList').text

interfaceName.append(i_app)

for p in elem.findall("params"):

print(p.find("name").attrib.get("type"))

print(p.find("value").text)

print(p.find("must").text)

# print(interfaceName)

return interfaceName

getXML("test4.xml")

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值