• python分享之读取xml文件(2)


    获得标签属性

    1. "1.0" encoding="utf-8"?>
    2. <catalog>
    3. <maxid>4maxid>
    4. <login username="pytest" passwd='123456'>
    5.   <caption>Pythoncaption>
    6. <item id="4">
    7. <caption>测试caption>
    8. item>
    9. login>
    10. <item id="2">
    11. <caption>Zopecaption>
    12. item>
    13. catalog>

    标签是有属性的,如何获得他们的属性?

    1. #coding=utf-8
    2. import xml.dom.minidom
    3. #打开xml文档
    4. dom = xml.dom.minidom.parse('abc.xml')
    5. #得到文档元素对象
    6. root = dom.documentElement
    7. itemlist = root.getElementsByTagName('login')
    8. item = itemlist[0]
    9. un=item.getAttribute("username")
    10. print un
    11. pd=item.getAttribute("passwd")
    12. print pd
    13. ii = root.getElementsByTagName('item')
    14. i1 = ii[0]
    15. i=i1.getAttribute("id")
    16. print i
    17. i2 = ii[1]
    18. i=i2.getAttribute("id")
    19. print i

    getAttribute方法可以获得元素的属性所对应的值。

    获得标签对之间的数据

    1. "1.0" encoding="utf-8"?>
    2. <catalog>
    3. <maxid>4maxid>
    4. <login username="pytest" passwd='123456'>
    5.   <caption>Pythoncaption>
    6. <item id="4">
    7. <caption>测试caption>
    8. item>
    9. login>
    10. <item id="2">
    11. <caption>Zopecaption>
    12. item>
    13. catalog>

    <caption>标签对之间是有数据的,如何获得这些数据?

    获得标签对之间的数据有多种方法,

    方法一

    1. #coding=utf-8
    2. import xml.dom.minidom
    3. #打开xml文档
    4. dom = xml.dom.minidom.parse('abc.xml')
    5. #得到文档元素对象
    6. root = dom.documentElement
    7. cc=dom.getElementsByTagName('caption')
    8. c1=cc[0]
    9. print c1.firstChild.data
    10. c2=cc[1]
    11. print c2.firstChild.data
    12. c3=cc[2]
    13. print c3.firstChild.data

    firstChild 属性返回被选节点的第一个子节点,.data表示获取该节点人数据。


    方法二

    1. #coding=utf-8
    2. from xml.etree import ElementTree as ET
    3. per=ET.parse('abc.xml')
    4. p=per.findall('./login/item')
    5. for oneper in p:
    6. for child in oneper.getchildren():
    7. print child.tag,':',child.text
    8. p=per.findall('./item')
    9. for oneper in p:
    10. for child in oneper.getchildren():
    11. print child.tag,':',child.text

    方法二有点复杂,所引用模块也与前面的不一样,findall用于指定在哪一级标签下开始遍历。

    getchildren方法按照文档顺序返回所有子标签。并输出标签名(child.tag)和标签的数据(child.text),其实,方法二的作用不在于此,它核心功能是可以遍历某一级标签下的所有子标签。

  • 相关阅读:
    示波器电流探头消磁如何正确操作
    大模型必备 - 中文最佳向量模型 acge_text_embedding
    RichView TRVStyle MainRVStyle
    适合零基础小白学的 Python 教程,视频或者书籍都可以?
    【MySQL】:约束全解析
    定了,JDK 19 功能集冻结,JDK官方终于支持支持协程了
    为什么信息图会帮助你的SEO
    数据存储策略——lsm-tree
    Vue脚手架④
    【狂神说:笔记】安全框架:shiro(入门)
  • 原文地址:https://blog.csdn.net/onebound/article/details/132720313