“Python中的类”的版本间差异

来自Shiyin's note
跳到导航 跳到搜索
无编辑摘要
第23行: 第23行:
===__getitem__===
===__getitem__===
*凡是在类中定义了这个__getitem__ 方法,那么它的实例对象(假定为p),可以像这样p[key] 取值,当实例对象做p[key] 运算时,会调用类中的方法__getitem__。
*凡是在类中定义了这个__getitem__ 方法,那么它的实例对象(假定为p),可以像这样p[key] 取值,当实例对象做p[key] 运算时,会调用类中的方法__getitem__。
class Taget:
def __init__(self,id):
self.id=id
def __getitem__(self, item):
print('这个方法被调用')
return self.id
a=Taget('This is id')
print(a.id)
b=a['python']
print(b)

2021年10月17日 (日) 06:11的版本

属性

可以为对象的属性使用双下划线开头,__xxx 。 双下划线开头的属性,是对象的隐藏属性,隐藏属性只能在类的内部访问,无法通过对象访问; 其实隐藏属性只不过是 Python自动为属性改了一个名字; 实际上是将名字修改为了,_类名__属性名 , 比如 __name -> _Person__name 。

装饰器

  • 使用@property装饰器来创建只读属性,@property装饰器会将方法转换为相同名称的只读属性,可以与所定义的属性配合使用,这样可以防止属性被修改。
class DataSet(object):
 @property
 def method_with_property(self): ##含有@property
     return 15
 def method_without_property(self): ##不含@property
     return 15
l = DataSet()
print(l.method_with_property) # 加了@property后,可以用调用属性的形式来调用方法,后面不需要加()。
print(l.method_without_property())  #没有加@property , 必须使用正常的调用方法的形式,即在后面加()

super

  • 通常情况下,我们在子类中定义了和父类同名的方法,那么子类的方法就会覆盖父类的方法。而super关键字实现了对父类方法的改写(增加了功能,增加的功能写在子类中,父类方法中原来的功能得以保留)。也可以说,super关键字帮助我们实现了在子类中调用父类的方法

__getitem__

  • 凡是在类中定义了这个__getitem__ 方法,那么它的实例对象(假定为p),可以像这样p[key] 取值,当实例对象做p[key] 运算时,会调用类中的方法__getitem__。
class Taget:
   def __init__(self,id):
       self.id=id
 
   def __getitem__(self, item):
       print('这个方法被调用')
       return self.id
 
a=Taget('This is id')
print(a.id)
b=a['python']
print(b)