介绍Python中⼏个常⽤的类⽅法
内置⽅法说明
__init__(self,...) 初始化对象,在创建新对象时调⽤
__del__(self) 释放对象,在对象被删除之前调⽤
__new__(cls,*args,**kwd) 实例的⽣成操作
__str__(self) 在使⽤print语句时被调⽤
__getitem__(self,key) 获取序列的索引key对应的值,等价于seq[key]
__len__(self) 在调⽤内联函数len()时被调⽤
python新手代码例子__cmp__(stc,dst) ⽐较两个对象src和dst
__getattr__(s,name) 获取属性的值
__setattr__(s,name,value) 设置属性的值
__delattr__(s,name) 删除name属性
__getattribute__() __getattribute__()功能与__getattr__()类似
__gt__(self,other) 判断self对象是否⼤于other对象
__lt__(slef,other) 判断self对象是否⼩于other对象
__ge__(slef,other) 判断self对象是否⼤于或者等于other对象
__le__(slef,other) 判断self对象是否⼩于或者等于other对象
__eq__(slef,other) 判断self对象是否等于other对象
__call__(self,*args) 把实例对象作为函数调⽤
__init__():
__init__⽅法在类的⼀个对象被建⽴时,马上运⾏。这个⽅法可以⽤来对你的对象做⼀些你希望的初始化。注意,这个名称的开始和结尾都是双下划线。
代码例⼦:
#!/usr/bin/python
# Filename: class_init.py
class Person:
def __init__(self, name):
self.name = name
def sayHi(self):
print 'Hello, my name is', self.name
p = Person('Swaroop')
p.sayHi()
输出:
Hello, my name is Swaroop
说明:__init__⽅法定义为取⼀个参数name(以及普通的参数self)。在这个__init__⾥,我们只是创建⼀个新的域,也称为name。注意它们是两个不同的变量,尽管它们有相同的名字。点号使我们能够区分它们。最重要的是,我们没有专门调⽤
__init__⽅法,只是在创建⼀个类的新实例的时候,把参数包括在圆括号内跟在类名后⾯,从⽽传递给__init__⽅法。这是这种⽅法的重要之处。现在,我们能够在我们的⽅法中使⽤self.name域。这在sayHi⽅法中得到了验证。
__new__():
__new__()在__init__()之前被调⽤,⽤于⽣成实例对象.利⽤这个⽅法和类属性的特性可以实现设计模式中的单例模式.单例模式是指创建唯⼀对象吗,单例模式设计的类只能实例化⼀个对象.
#!/usr/bin/python
# -*- coding: UTF-8 -*-
class Singleton(object):
__instance = None # 定义实例
def __init__(self):
pass
def __new__(cls, *args, **kwd): # 在__init__之前调⽤
if Singleton.__instance is None: # ⽣成唯⼀实例
Singleton.__instance = object.__new__(cls, *args, **kwd)
return Singleton.__instance
__getattr__()、__setattr__()和__getattribute__():
当读取对象的某个属性时,python会⾃动调⽤__getattr__()⽅法.例如,lor将转换为fruit.__getattr__(color).当使⽤赋值语句对属性进⾏设置时,python会⾃动调⽤__setattr__()⽅法.__getattribute__()的功能与__getattr__()类似,⽤于获取属性的值.但是__getattribute__()能提供更好的控制,代码更健壮.注意,python中并不存在__setattribute__()⽅法.
代码例⼦:
#!/usr/bin/python
# -*- coding: UTF-8 -*-
class Fruit(object):
def __init__(self, color = "red", price = 0):
self.__color = color
self.__price = price
def __getattribute__(self, name): # 获取属性的⽅法
return object.__getattribute__(self, name)
def __setattr__(self, name, value):
self.__dict__[name] = value
if __name__ == "__main__":
fruit = Fruit("blue", 10)
print fruit.__dict__.get("_Fruit__color") # 获取color属性
fruit.__dict__["_Fruit__price"] = 5
print fruit.__dict__.get("_Fruit__price") # 获取price属性
__getitem__():
如果类把某个属性定义为序列,可以使⽤__getitem__()输出序列属性中的某个元素.假设⽔果店中销售多钟⽔果,可以通过
__getitem__()⽅法获取⽔果店中的没种⽔果
代码例⼦:
#!/usr/bin/python
# -*- coding: UTF-8 -*-class FruitShop:
def __getitem__(self, i): # 获取⽔果店的⽔果
return self.fruits[i]
if __name__ == "__main__":
shop = FruitShop()
shop.fruits = ["apple", "banana"]
print shop[1]
for item in shop: # 输出⽔果店的⽔果
print item,
输出为:
banana
apple banana
__str__():
__str__()⽤于表⽰对象代表的含义,返回⼀个字符串.实现了__str__()⽅法后,可以直接使⽤print语句输出对象,也可以通过函数str()触发__str__()的执⾏.这样就把对象和字符串关联起来,便于某些程序的实现,可以⽤这个字符串来表⽰某个类
代码例⼦:
#!/usr/bin/python
# -*- coding: UTF-8 -*-
class Fruit:
'''Fruit类''' #为Fruit类定义了⽂档字符串
def __str__(self): # 定义对象的字符串表⽰
return self.__doc__
if __name__ == "__main__":
fruit = Fruit()
print str(fruit) # 调⽤内置函数str()出发__str__()⽅法,输出结果为:Fruit类
print fruit #直接输出对象fruit,返回__str__()⽅法的值,输出结果为:Fruit类
__call__():
在类中实现__call__()⽅法,可以在对象创建时直接返回__call__()的内容.使⽤该⽅法可以模拟静态⽅法
代码例⼦:
#!/usr/bin/python
# -*- coding: UTF-8 -*-
class Fruit:
class Growth: # 内部类
def __call__(self):
print "grow ..."
grow = Growth() # 调⽤Growth(),此时将类Growth作为函数返回,即为外部类Fruit定义⽅法grow(),grow()将执⾏__call__()内的代码
if __name__ == '__main__':
fruit = Fruit()
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论