从最初的'hello world',走到面向对象。该回过头来看看,教程中是否遗漏了什么。
我们之前提到一句话,"Everything is Object(一切都是对象)"。那么我们就深入体验一下这句话。
需要先介绍两个内置函数,dir()
和help()
dir()用来查询一个类或者对象所有属性。你可以尝试一下
>>>print dir(list)
help()用来查询的说明文档。你可以尝试一下
>>>print helo(list)
list是一个类
在上面已经看到,表示Python已经定义好的一类。当我们新建一个表时,比如:
>>>n1 = [1,2,5,3,5]
实际上,n1是类list的一个对象。
实验一些list的方法:
>>>print n1.count(5) # 计数,看总共有多少个5
>>>print n1.index(3) # 查询n1的第一个3的下标
>>>n1.append(6) # 在n1的最后增添一个新元素6
>>>n1.sort() # 对n1的元素进行排序
>>>print n1,pop() # 从n1中去除最后一个元素,并将该元素返回。
>>>n1.remove(2) # 从n1中去除第一个2
>>>n1.insert(0,9) # 在下标为0的位置插入9
总之,list是一个类。每个列表都属于该类。
Python补充中有list常用方法的附录。
运算符是特殊方法
使用dir(list)的时候,能看到一个属性,是add()。从形式上看是特殊方法(__两个下划线)。它特殊在哪呢?
这个方法定义了"+"运算符对于list对象的定义,两个list的对象相加时,会进行的操作。
>>>print [1,2,3] + [5,6,9]
运算符,比如+,-,>,<,以及下标引用[start:end]等等,从根本上都是定义在类内部的方法。
尝试一下
>>>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])
内置函数len()用来返回list所包含的元素的综述。内置函数sub()定义了"-"的操作:从第一个表中去掉第二个表中出现的元素。如果sub()已经在父类中定义,你又在子类中定义了,那么子类的对象会参考子类的定义,而不会载入父类的定义。任何其他的属性也是这样。(教程最后也会给出一个特殊方法的清单)
定义运算符对于复杂的对象非常有用。举例来说,人类又多个属性,比如姓名,年龄和身高。我们可以把人类的比较(>,<,=)定义成只看年龄。这样就可以根据自己的目的。将原本不存在的运算增加在对象上了。
下一步
希望你已经对Python有了一个基本了解。你可能跃跃欲试,要写一些程序练习一下。这会对你很有好处。
但是,Python的强大很大一部分原因在于,它提供有很多已经写好的,可以现成用的对象。我们已经看到了内置的比如说list,还有tuple等等。它们用起来很方便。在Python的标准库里,还有大量可以用于操作系统互动,Internet开发,多线程,文本处理的对象。而在所有的这些的这些的基础上,又有很多外部的库包,定义了更丰富的对象,比如numpy, tkinter, django等用于科学计算,GUI开发,web开发的库,定义了各种各样的对象。对于一般用户来说,使用这些库,要比自己去从头开始容易得多。我们要开始攀登巨人的肩膀了。
谢谢你的关注,
欢迎来到Python的世界。
总结
len() dir() help()
数据结构list(列表)是一个类。
运算符是方法