“Python中的类”的版本间差异
		
		
		
		
		
		跳到导航
		跳到搜索
		
				
		
		
	
无编辑摘要  | 
				|||
| 第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)