-
直接给属性赋值无法检查分数的有效性。 因为Python支持高阶函数,在函数式编程中我们介绍了装饰器函数,可以用装饰器函数把 get/set 方法“装饰”成属性调用 注意: 第一个score(self)是get方法,用@property装饰,第二个score(self, score)是set方法,用@score.setter装饰,@score.setter是前一个@property装饰后的副产品。查看全部
-
类型转换 __int__, __float__ 等等查看全部
-
__len__()方法,就可以用len()函数返回Students实例的“长度”查看全部
-
if self.score==s.score: return cmp(self.name,s.name) return -cmp(self.score,s.score)查看全部
-
s.upper() de yong fa查看全部
-
正确实现特殊方法查看全部
-
Python部分特殊方法查看全部
-
特殊方法查看全部
-
首先可以用 type() 函数获取变量的类型,它返回一个 Type 对象 其次,可以用 dir() 函数获取变量的所有属性 对于实例变量,dir()返回所有实例属性,包括`__class__`这类有特殊意义的属性。注意到方法`whoAmI`也是 s 的一个属性。 如何去掉`__xxx__`这类的特殊属性,只保留我们自己定义的属性?回顾一下filter()函数的用法。 dir()返回的属性是字符串列表,如果已知一个属性名称,要获取或者设置对象的属性,就需要用 getattr() 和 setattr( )函数 传入**kw 即可传入任意数量的参数,并通过 setattr() 绑定属性。 >>> getattr(s, 'age', 20) # 获取age属性,如果属性不存在,就返回默认值20:查看全部
-
多重继承的目的是从两种继承树中分别选择并继承出子类,以便组合功能使用。 像这样,D 同时继承自 B 和 C,也就是 D 拥有了 A、B、C 的全部功能。多重继承通过 super()调用__init__()方法时,A 虽然被继承了两次,但__init__()只调用一次查看全部
-
由于Python的动态特性,json.load()并不一定要从一个File对象读取内容。任何对象,只要有read()方法,就称为File-like Object,都可以传给json.load()。查看全部
-
方法调用将作用在 x 的实际类型上。s 是Student类型,它实际上拥有自己的 whoAmI()方法以及从 Person继承的 whoAmI方法,但调用 s.whoAmI()总是先查找它自身的定义,如果没有定义,则顺着继承链向上查找,直到在某个父类中找到为止。 由于Python是动态语言,所以,传递给函数 who_am_i(x)的参数 x 不一定是 Person 或 Person 的子类型。任何数据类型的实例都可以,只要它有一个whoAmI()的方法即可: class Book(object): def whoAmI(self): return 'I am a book' 这是动态语言和静态语言(例如Java)最大的差别之一。动态语言调用实例方法,不检查类型,只要方法存在,参数正确,就可以调用。查看全部
-
一个实例可以看成它本身的类型,也可以看成它父类的类型。 isinstance(实例, 类名) 判断实例是否是该类查看全部
-
一定要用 super(Student, self).__init__(name, gender) 去初始化父类,否则,继承自 Person 的 Student 将没有 name 和 gender。查看全部
-
注意类方法需要添加 @classmethod 方法的第一个参数将传入类本身,通常将参数名命名为 cls cls.count 实际上相当于 Person.count。查看全部
举报
0/150
提交
取消