标签:

作者:Vamei 出处:

之前提到一句话: everything is object, 下面我们局深入体验一下这句话

需要先介绍两个内置函数, dir(), help()

dir() 用来查询一个类活或者对象所有的属性,

>>> print dir(list)

help() 用来查询说明文档

>>> print help(list)

list 是一个类

在上面以及看到,表是Python已经定义好的一个类。当我们新建一个表时,比如:

>>>nl = [1,2,5,3,5]

实际上,nl是类list的一个对象。

实验一些list的方法:

>>>print nl.count(5)       # 计数,看总共有多少个5

>>>print nl.index(3)       # 查询 nl 的第一个3的下标

>>>nl.append(6)            # 在 nl 的最后增添一个新元素6

>>>nl.sort()               # 对nl的元素排序

>>>print nl.pop()          # 从nl中去除最后一个元素,并将该元素返回。

>>>nl.remove(2)            # 从nl中去除第一个2

>>>nl.insert(0,9)          # 在下标为0的位置插入9

总之,list是一个类。每个列表都属于该类。

Python补充中有list常用方法的附录。

运算符是 特殊方法

使用dir(list)的时候,能看到一个属性,是__add__()。从形式上看是特殊方法(下划线,下划线)。它特殊在哪呢?

这个方法定义了"+"运算符对于list对象的意义,两个list的对象相加时,会进行的操作。

>>> print [1,2,3] + [5,6,9]

output [1, 2, 3, 5, 6, 9]

运算符,比如+, -, >,

尝试一下

尝试一下

>>>print [1,2,3] - [3,4]

会有错误信息,说明该运算符“-”没有定义。现在我们继承list类,添加对"-"的定义

class superList(list):

def __sub__(self, b):

a = self[:]     # 这里,self是supeList的对象。由于superList继承于list,它可以利用和list[:]相同的引用方法来表示整个对象。

b = b[:]

while len(b) > 0:

element_b = b.pop()

if element_b in a:

a.remove(element_b)

return a

print superList([1,2,3]) - superList([3,4])

class superList(list):

def __sub__(self, b):

a = self[:]

b = b[:]

while len(b) > 0:

element_b = b.pop()

if element_b in a:

a.remove(element_b)

return a

内置函数len()用来返回list所包含的元素的总数。内置函数__sub__()定义了“-”的操作:从第一个表中去掉第二个表中出现的元素。如果__sub__()已经在父类中定义,你又在子类中定义了,那么子类的对象会参考子类的定义,而不会载入父类的定义。任何其他的属性也是这样。

(教程最后也会给出一个特殊方法的清单)

定义运算符对于复杂的对象非常有用。举例来说,人类有多个属性,比如姓名,年龄和身高。我们可以把人类的比较(>,

下一步

Python的强大的很大一部分原因在于, 它提供有很多 已经写好的,可以现成用的对象, 我们已经看到了内置的 比如list tuple 等等。 它们用起来很方便 在python的标准库里,还有大量乐意用于 操作系统互动, internet开发, 多线程, 文本处理的对象。 而在所有的这些基础上,又有很多外部的库包,定义了更丰富的对象, 比如 numpy, tkinter, django等用于科学计算,GUI开发, web开发的库。