xml 文档,无非就是一个树状的数据仓库,最基础的部分也就四个:增删改查。
解析树状结构
注意:xml.etree.ElementTree模块在应对恶意结构数据时显得并不安全。
1 | from xml.etree import ElementTree |
注意:从字符串读取时不需要parse,因为fromstring直接返回的就是我们的root节点。
1 | from xml.etree import ElementTree |
其中,tree比较好理解,就是我们的xml文件的树。root也就是我们的根节点。
root属于element对象,有以下几个属性:
- tag:string对象,表示数据代表的种类。
- attrib:dictionary对象,表示附有的属性。
- text:string对象,表示element的内容。
- tail:string对象,表示element闭合之后的尾迹。
- 若干子元素(child elements)。这些子元素可以通过index索引。
1 | <tag attrib1=1>text</tag>tail |
小技巧:若想加快速度,可以使用C语言编译的API xml.etree.cElementTree。在import时考虑优先导入,代码修改如下。
1 | try: |
ElementTree.Element Class
1 | class xml.etree.ElementTree.Element(tag, attrib={}, **extra) |
ElementTree Object
1 | class xml.etree.ElementTree.ElementTree(element=None, file=None) |
增删改查
我思考了一下,面向对象的方法更容易思考,也更容易整理思路。在实际使用的时候要把上面的这些作为某一个xml文件对象的方法然后整理成一个单独的Class。
AI-tuner 小项目中的实际应用:
1 | class xmlResolver(xmlFilePath) |
Python 面向对象回顾
方法
self 代表类的实例,self 在定义类的方法时是必须有的,虽然在调用时不必传入相应的参数。
init()方法是一种特殊的方法,被称为类的构造函数或初始化方法,当创建了这个类的实例时就会调用该方法。
类的内置属性
dict : 类的属性(包含一个字典,由类的数据属性组成)
doc :类的文档字符串
name: 类名
module: 类定义所在的模块(类的全名是’main.className’,如果类位于一个导入模块mymod中,那么className.module 等于 mymod)
bases : 类的所有父类构成元素(包含了一个由所有父类组成的元组)
子类父类
1 | class 派生类名(基类名) |
注意:python允许多父类继承,叫做多重继承。
然后方法重写的概念在python中是指子类重写父类的方法,这一点和Java有出入。
基础的重载方法
序号 | 方法 | 描述 | 简单应用 |
---|---|---|---|
1 | init ( self [,args…] ) | 构造函数 | 简单的调用方法: obj = className(args) |
2 | del( self ) | 析构方法, 删除一个对象 | 简单的调用方法 : del obj |
3 | repr( self ) | 转化为供解释器读取的形式 | 简单的调用方法 : repr(obj) |
4 | str( self ) | 用于将值转化为适于人阅读的形式 | 简单的调用方法 : str(obj) |
5 | cmp ( self, x ) | 对象比较 | 简单的调用方法 : cmp(obj, x) |
私有类方法
__private_method:两个下划线开头,声明该方法为私有方法,不能在类的外部调用。在类的内部调用 self.__private_methods
单下划线、双下划线、头尾双下划线说明
foo: 定义的是特殊方法,一般是系统定义名字 ,类似 init() 之类的。
_foo: 以单下划线开头的表示的是 protected 类型的变量,即保护类型只能允许其本身与子类进行访问,不能用于 from module import *
__foo: 双下划线的表示的是私有类型(private)的变量, 只能是允许这个类本身进行访问了。