Python3 XML解析

Python3 XML解析

python有三种方法解析XML,SAX,DOM、ElementTree

在python中使用sax方式处理xml要先引入xml.sax中的parse函数,还有xml.sax.handler中的ContentHandler。

ContentHandler类方法介绍

characters(content)方法

调用时机:

从行开始,遇到标签之前,存在字符,content的值为这些字符串。

从一个标签,遇到下一个标签之前, 存在字符,content的值为这些字符串。

从一个标签,遇到行结束符之前,存在字符,content的值为这些字符串。

标签可以是开始标签,也可以是结束标签。

startDocument()方法

文档启动的时候调用。

endDocument()方法

解析器到达文档结尾时调用。

startElement(name, attrs)方法

遇到XML开始标签时调用,name是标签的名字,attrs是标签的属性值字典。

endElement(name)方法

遇到XML结束标签时调用。

parser方法

以下方法创建一个 SAX 解析器并解析xml文档:

xml.sax.parse( xmlfile, contenthandler[, errorhandler])

参数说明:

  • xmlfile - xml文件名
  • contenthandler - 必须是一个ContentHandler的对象
  • errorhandler - 如果指定该参数,errorhandler必须是一个SAX ErrorHandler对象

使用xml.dom解析xml

一个 DOM 的解析器在解析一个 XML 文档时,一次性读取整个文档,把文档中所有元素保存在内存中的一个树结构里,之后你可以利用DOM 提供的不同的函数来读取或修改文档的内容和结构,也可以把修改过的内容写入xml文件。

from xml.dom.minidom import parse
doc=parse("xmljiexi.xml")
root=doc.documentElement
movies=root.getElementsByTagName("book")
for movie in movies:
   print("")
   #获取子节点的值.childNodes[0].data
   type = movie.getElementsByTagName('bookname')[0]
   print("Type: %s" % type.childNodes[0].data)
以上程序执行结果如下:
Type: Java

Type: python入门

Type: 神雕侠侣



猜你喜欢

转载自blog.csdn.net/NingSuo123/article/details/80724675