已知movies.xml

  1. <collection shelf="New Arrivals">
  2. <movie title="Enemy Behind">
  3. <type>War, Thriller</type>
  4. <format>DVD</format>
  5. <year>2003</year>
  6. <rating>PG</rating>
  7. <stars>10</stars>
  8. <description>Talk about a US-Japan war</description>
  9. </movie>
  10. <movie title="Transformers">
  11. <type>Anime, Science Fiction</type>
  12. <format>DVD</format>
  13. <year>1989</year>
  14. <rating>R</rating>
  15. <stars>8</stars>
  16. <description>A schientific fiction</description>
  17. </movie>
  18. <movie title="Trigun">
  19. <type>Anime, Action</type>
  20. <format>DVD</format>
  21. <episodes>4</episodes>
  22. <rating>PG</rating>
  23. <stars>10</stars>
  24. <description>Vash the Stampede!</description>
  25. </movie>
  26. <movie title="Ishtar">
  27. <type>Comedy</type>
  28. <format>VHS</format>
  29. <rating>PG</rating>
  30. <stars>2</stars>
  31. <description>Viewable boredom</description>
  32. </movie>
  33. </collection>

Python 解析XML实例

  1. # -*- coding: UTF-8 -*-
  2. import xml.sax
  3. class MovieHandler( xml.sax.ContentHandler ):
  4. def __init__(self):
  5. self.CurrentData = ""
  6. self.type = ""
  7. self.format = ""
  8. self.year = ""
  9. self.rating = ""
  10. self.stars = ""
  11. self.description = ""
  12. # 元素开始事件处理
  13. def startElement(self, tag, attributes):
  14. self.CurrentData = tag
  15. if tag == "movie":
  16. print("*****Movie*****")
  17. title = attributes["title"]
  18. print("Title:", title)
  19. # 元素结束事件处理
  20. def endElement(self, tag):
  21. if self.CurrentData == "type":
  22. print ("Type:", self.type)
  23. elif self.CurrentData == "format":
  24. print ("Format:", self.format)
  25. elif self.CurrentData == "year":
  26. print ("Year:", self.year)
  27. elif self.CurrentData == "rating":
  28. print( "Rating:", self.rating)
  29. elif self.CurrentData == "stars":
  30. print( "Stars:", self.stars)
  31. elif self.CurrentData == "description":
  32. print ("Description:", self.description)
  33. self.CurrentData = ""
  34. # 内容事件处理
  35. def characters(self, content):
  36. if self.CurrentData == "type":
  37. self.type = content
  38. elif self.CurrentData == "format":
  39. self.format = content
  40. elif self.CurrentData == "year":
  41. self.year = content
  42. elif self.CurrentData == "rating":
  43. self.rating = content
  44. elif self.CurrentData == "stars":
  45. self.stars = content
  46. elif self.CurrentData == "description":
  47. self.description = content
  48. if ( __name__ == "__main__"):
  49. # 创建一个 XMLReader
  50. parser = xml.sax.make_parser()
  51. # turn off namepsaces
  52. parser.setFeature(xml.sax.handler.feature_namespaces, 0)
  53. # 重写 ContextHandler
  54. Handler = MovieHandler()
  55. parser.setContentHandler( Handler )
  56. parser.parse("movies.xml")

结果:

  1. *****Movie*****
  2. Title: Enemy Behind
  3. Type: War, Thriller
  4. Format: DVD
  5. Year: 2003
  6. Rating: PG
  7. Stars: 10
  8. Description: Talk about a US-Japan war
  9. *****Movie*****
  10. Title: Transformers
  11. Type: Anime, Science Fiction
  12. Format: DVD
  13. Year: 1989
  14. Rating: R
  15. Stars: 8
  16. Description: A schientific fiction
  17. *****Movie*****
  18. Title: Trigun
  19. Type: Anime, Action
  20. Format: DVD
  21. Rating: PG
  22. Stars: 10
  23. Description: Vash the Stampede!
  24. *****Movie*****
  25. Title: Ishtar
  26. Type: Comedy
  27. Format: VHS
  28. Rating: PG
  29. Stars: 2
  30. Description: Viewable boredom

Python 解析XML实例(xml.sax)的更多相关文章

  1. python解析VOC的xml文件并转成自己需要的txt格式

    在进行神经网络训练的时候,自己标注的数据集往往会有数据量不够大以及代表性不强等问题,因此我们会采用开源数据集作为训练,开源数据集往往具有特定的格式,如果我们想将开源数据集为我们所用的话,就需要对其格式 ...

  2. python cookbook第三版学习笔记七:python解析csv,json,xml文件

    CSV文件读取: Csv文件格式如下:分别有2行三列. 访问代码如下: f=open(r'E:\py_prj\test.csv','rb') f_csv=csv.reader(f) for f in ...

  3. python 解析与生成xml

    xml.etree.ElementTree模块为xml文件的提取和建立提供了简单有效的API.下文中使用ET来代表xml.etree.ElementTree模块. XML是一种内在的分层的数据形式,展 ...

  4. python解析Yahoo的XML格式的天气预报,获取当天和近期几天的天气:

    下面是接口xml格式数据: <rss xmlns:yweather="http://xml.weather.yahoo.com/ns/rss/1.0" xmlns:geo=& ...

  5. Python解析Yahoo的XML格式的天气预报数据

    以下是Yahoo天气预报接口xml格式数据: <rss xmlns:yweather="http://xml.weather.yahoo.com/ns/rss/1.0" xm ...

  6. python解析robot framework的output.xml,并生成html

    一.背景 Jenkins自动构建RF脚本,生成的RF特有HTML报告不能正常打开. 需求:用Python解析测试报告的xml数据,放在普通HTML文件中打开 二.output.xml数据 三.用pyh ...

  7. Python解析生成XML-ElementTree VS minidom

    OS:Windows 7 关键字:Python3.4,XML,ElementTree,minidom 本文介绍用Python解析生成以下XML: <Persons> <Person& ...

  8. python 解析xml 文件: SAX方式

    环境 python:3.4.4 准备xml文件 首先新建一个xml文件,countries.xml.内容是在python官网上看到的. <?xml version="1.0" ...

  9. [转载] python 解析xml 文件: SAX方式

    环境 python:3.4.4 准备xml文件 首先新建一个xml文件,countries.xml.内容是在python官网上看到的. <?xml version="1.0" ...

随机推荐

  1. java-多态中成员访问特点-父类引用指向子类对象

    多态前提: - 要有继承关系. - 要有方法重写. - 要有父类引用指向子类对象. 1.成员变量:编译看左边(父类),运行看左边(父类) 2.成员方法:编译看左边(父类),运行看右边(子类),动态绑定 ...

  2. java-权限修饰符的区别

    说明:所谓访问权限,是指对象是否可以通过“.”运算符操作自己的变量或通过“.”运算符使用类中的方法. 1.Java中的四种访问修饰符:public.protected.default(无修饰符,默认) ...

  3. linux下使用小票打印

    linux下使用小票打印 打印机: Xprinter XP-58IIH指令支持: ESC/POS接口: USB, 蓝牙 Linux系统: Centos7 蓝牙配对很快, 配对好后就是连接状态. 但很快 ...

  4. gogs打造自己的git

    推荐docker安装 //下载镜像 docker pull gogs/gogs // 创建容器 docker run -d --name=gogs -p 10022:22 -p 3000:3000 - ...

  5. 实验吧—安全杂项——WP之 女神

    点击链接下载压缩文件解压后得到 打开TXT文档: 能看出是base64,这么长,那就是转成图片喽~ 地址:http://www.vgot.net/test/image2base64.php? 然后就是 ...

  6. AC自动机自我理解和模板

    给出长度为m的文本 查询 n个单词出现的次数 用kmp 复杂度 n*m*(单词平均长度) 用字典树 复杂度 m*每次字典树遍历的平均深度) AC自动机 复杂度 m (思路可以理解为kmp+字典树 ) ...

  7. Redis(二)持久化

    Redis持久化,分为RDB方式和AOF方式,它们可以单独使用,也可以混用.Redis默认的是使用RDB方式. 一.RDB方式 1.触发快照的方式 RDB方式是在指定时间间隔内某一时间点的数据集快照. ...

  8. mysql 服务器启用event_scheduler

    https://blog.csdn.net/yangzefei1991/article/details/51800867 首先在sql中查询计划事件的状态:SHOW VARIABLES LIKE 'e ...

  9. 【Jmeter】分布式并发测试

    一.前提: 1.最近在做一下压测,但是单台服务器的CPU,内存可能不够支撑压测的项目,这时候,我们可以使用Jmeter分布式压测. 2.本次使用的环境: 1台服务器做master(调度器) 5台服务器 ...

  10. python.numpy.std()计算矩阵标准差

    >>> a = np.array([[1, 2], [3, 4]]) >>> np.std(a) # 计算全局标准差 1.1180339887498949 > ...