相关文章推荐
冲动的显示器  ·  XML 模式:了解命名空间·  1 月前    · 
坚韧的小刀  ·  利用Saxon和xslt进行xml的格式转换 ...·  4 周前    · 
讲道义的脸盆  ·  解析或序列化 XML - ...·  3 周前    · 
想发财的野马  ·  JavaScript实现解析xml文件数据_ ...·  3 周前    · 
逃课的黑框眼镜  ·  使用架构(XSD)验证XML文件 - 陈希章 ·  2 周前    · 
紧张的烤面包  ·  vue.js - How to ...·  2 年前    · 
怕老婆的钱包  ·  【错误记录】NDK 动态库报错 ( ...·  2 年前    · 
逼格高的自行车  ·  Android—Room数据库多表查询(Re ...·  2 年前    · 
Code  ›  【Python】解析 Xml 格式的文档开发者社区
root string xml解析 xml语言
https://cloud.tencent.com/developer/article/1947727
迷茫的鸵鸟
2 年前
作者头像
杨丝儿
0 篇文章

【Python】解析 Xml 格式的文档

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > 杨丝儿的小站 > 【Python】解析 Xml 格式的文档

【Python】解析 Xml 格式的文档

作者头像
杨丝儿
发布 于 2022-02-25 20:18:50
828 0
发布 于 2022-02-25 20:18:50
举报

xml 文档,无非就是一个树状的数据仓库,最基础的部分也就四个:增删改查。

解析树状结构

  • 从硬盘读取
  • 从字符串读取

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

from xml.etree import ElementTree
# import data from our dataset
tree = ElementTree.parse([path of xml file])
# pick the root of xml tree
root = tree.getroot()

注意:从字符串读取时不需要parse,因为fromstring直接返回的就是我们的root节点。

from xml.etree import ElementTree
# pick the root of xml tree
root = ElementTree.fromstring(country_data_as_string)

其中,tree比较好理解,就是我们的xml文件的树。root也就是我们的根节点。

root属于element对象,有以下几个属性:

  1. tag:string对象,表示数据代表的种类。
  2. attrib:dictionary对象,表示附有的属性。
  3. text:string对象,表示element的内容。
  4. tail:string对象,表示element闭合之后的尾迹。
  5. 若干子元素(child elements)。这些子元素可以通过index索引。
<tag attrib1=1>text</tag>tail
  1     2        3         4

小技巧:若想加快速度,可以使用C语言编译的API xml.etree.cElementTree。在import时考虑优先导入,代码修改如下。

try:
    import xml.etree.cElementTree as ET
except ImportError:
    import xml.etree.ElementTree as ET

ElementTree.Element Class

class xml.etree.ElementTree.Element(tag, attrib={}, **extra)
    tag:string,元素代表的数据种类。
    attrib:dictionary,元素的属性字典。
    text:string,元素的内容。
    tail:string,元素的尾形。
    # 针对属性的操作
    clear():清空元素的后代、属性、text和tail也设置为None。
    get(key, default=None):获取key对应的属性值,如该属性不存在则返回default值。
    items():根据属性字典返回一个列表,列表元素为(key, value)。
    keys():返回包含所有元素属性键的列表。
    set(key, value):设置新的属性键与值。
    # 针对后代的操作
    ## 增加新的element
    append(subelement):添加直系子元素。
    extend(subelements):增加一串元素对象作为子元素。
    insert(index, element):在指定位置插入子元素。
    ## 删除element
    remove(subelement):删除子元素。
    ## 遍历elements,得到iter或者list
    find(match):寻找第一个匹配子元素,匹配对象可以为tag或path。
    findall(match):寻找所有匹配子元素,匹配对象可以为tag或path。
    findtext(match):寻找第一个匹配子元素,返回其text值。匹配对象可以为tag或path。
    iter(tag=None):生成遍历当前元素所有后代或者给定tag的后代的迭代器。
    iterfind(match):根据tag或path查找所有的后代。
    itertext():遍历所有后代并返回text值。

ElementTree Object

class xml.etree.ElementTree.ElementTree(element=None, file=None)
    element如果给定,则为新的ElementTree的根节点。
    _setroot(element):用给定的element替换当前的根节点。慎用。
    getroot():获取根节点。
    parse(source, parser=None):装载xml对象,source可以为文件名或文件类型对象。
    # 写回方法write
    write(file, encoding="us-ascii", xml_declaration=None, default_namespace=None,method="xml")
    # 以下方法与Element类中同名方法近似,区别在于它们指定以根节点作为操作对象。
    find(match)
 
推荐文章
冲动的显示器  ·  XML 模式:了解命名空间
1 月前
坚韧的小刀  ·  利用Saxon和xslt进行xml的格式转换_saxon-he
4 周前
讲道义的脸盆  ·  解析或序列化 XML - XML:可扩展标记语言 | MDN
3 周前
想发财的野马  ·  JavaScript实现解析xml文件数据_js解析xml
3 周前
逃课的黑框眼镜  ·  使用架构(XSD)验证XML文件 - 陈希章
2 周前
紧张的烤面包  ·  vue.js - How to export a function - Stack Overflow
2 年前
怕老婆的钱包  ·  【错误记录】NDK 动态库报错 ( dlopen failed: file offset for the library /lib/arm64/libwebp.so“ >= file size:0)_韩曙亮的博客-CSDN博客
2 年前
逼格高的自行车  ·  Android—Room数据库多表查询(Relationships)-腾讯云开发者社区-腾讯云
2 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号