• 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),其实,方法二的作用不在于此,它核心功能是可以遍历某一级标签下的所有子标签。

  • 相关阅读:
    golang中的锁竞争问题
    分析SSH登录日志
    技术干货|如何使用昇思MindSpore自定义优化器
    Ui自动化测试如何上传文件
    JVM参数调优推荐
    TCP/IP 三次握手&四次挥手详解,以及异常状态分析
    iOS 用masonry布局Scrollview的问题,添加在scrollview的子控件约束失效
    ubuntu20.04 安装 pyconcorde
    金山云冲刺港股拟双重主要上市:年营收90亿 为雷军力挺项目
    Nginx使用教程
  • 原文地址:https://blog.csdn.net/onebound/article/details/132720313