python解析xml文件

矫情吗;* 2022-05-11 02:34 394阅读 0赞

最近有个问题需要解析xml文件,以前没接触过,完成后发现原来解析xml很简单,但还是记录一下相关概念与解析过程,日后查看方便查找。

country_data.xml文件如下所示,找的是一个大家常用的demo,貌似是官网公布的(没确认过):

  1. <?xml version="1.0"?>
  2. <data>
  3. <country name="Liechtenstein">
  4. <rank>1</rank>
  5. <year>2008</year>
  6. <gdppc>141100</gdppc>
  7. <neighbor name="Austria" direction="E"/>
  8. <neighbor name="Switzerland" direction="W"/>
  9. </country>
  10. <country name="Singapore">
  11. <rank>4</rank>
  12. <year>2011</year>
  13. <gdppc>59900</gdppc>
  14. <neighbor name="Malaysia" direction="N"/>
  15. </country>
  16. <country name="Panama">
  17. <rank>68</rank>
  18. <year>2011</year>
  19. <gdppc>13600</gdppc>
  20. <neighbor name="Costa Rica" direction="W"/>
  21. <neighbor name="Colombia" direction="E"/>
  22. </country>
  23. <country2 name="Test">
  24. <rank>234</rank>
  25. <year>2016</year>
  26. <gdppc>346344</gdppc>
  27. <neighbor name="Costa Rica" direction="W"/>
  28. <neighbor name="Colombia" direction="E"/>
  29. </country2>
  30. </data>

先解释下一些概念,很简单的:

  1. 1.第一行的`<?xml version="1.0" encoding="UTF-8"?>`xml文件的声明,它定义了xml的版本 (1.0)和所使用编码为UTF-8
  2. 2.接下来就是xml文件的内容了,这些内容按一个树状结构进行组织摆放,形式如下:
  3. <root>
  4. <child>
  5. <subchild>.....</subchild>
  6. <subchild>.....</subchild>
  7. </child>
  8. </root>

其中,每一个<XXX>.</XXX>叫做一个节点,也叫一个元素,节点可以嵌套放置,也可以并列放置,在嵌套结构中,内外层节点是父子关系,以此类推,最外层的节点都叫做根节点。并列的两节点为兄弟关系。
3.对于每一个节点,一般由Tag、Attribute、Text三部分构成。在country_data.xml中data,country,rank,year这些都是tag。与tag同一尖括弧内右边的是Attribute,比如:name。Text就是两个尖括弧中间夹的东西了。

节点的遍历,也很简单的:

  1. xml文件的信息都存在节点里,关于节点的遍历,有好几种方法,我用的是Element Tree。代码如下:
  2. from xml.etree import ElementTree as ET
  3. def main():
  4. # 读取xml文件
  5. tree = ET.parse('./test.xml')
  6. # 获取根节点
  7. root = tree.getroot()
  8. print("root.tag :",root.tag)
  9. # 获取当前根节点下的左右子country节点
  10. child_node_list = root.findall('./country_data.xml')
  11. # 打印每个country节点的Attribute
  12. for child_node in child_node_list:
  13. print(child_node.attrib)
  14. # 获取某一个节点的text,以<rank>234</rank>为例
  15. node = root.find('country2/rank')
  16. print(node.text)
  17. if __name__ == '__main__':
  18. main()

输出结果:
在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,394人围观)

还没有评论,来说两句吧...

相关阅读

    相关 python解析xml文件

        最近有个问题需要解析xml文件,以前没接触过,完成后发现原来解析xml很简单,但还是记录一下相关概念与解析过程,日后查看方便查找。 country\_data.x