巩固结论: __init__函数, 只是多了个自动执行的功能, 但未实例化的时候, 其也是普通函
数, 其内部的属性作用域在函数之内, 故而下例查不到类中的__init__中的属性, 但是类实例化之后, 就可以查到了. 也就是,这种属性, 只能被调用后才能检查得到, 因为实例化调用__init__函数后, 其内部的带self.开头的属性, 变成了作用域是实例内部的属性(其他被调用后的函数也一样, 调用了之后带self.的属性, 就是实例的属性了.). 函数只是一堆静态的数据, 实例化之后, 其开始运动, 将数据处理传送, 最后输出.
# 判断类有没有某个属性, 目前只能测试出方法属性, 没法测试出类属性
class Student(object):
classText = ''
def __init__(self, name=None, age=None):
self.name = name
self.age = age
self.mobile = 137
@classmethod
def reInitInfo(abc, info):
name, age = info.split(' ')
return abc(name, age)
def info(self):
print(self.name)
print(self.age)
@staticmethod
def func(x, y):
print(x + str(y))
stu = Student("Oliver", 17)
# 类属性确定
print('Student有属性classText: {}'.format(hasattr(Student, 'classText')))
print('Student有属性info: {}'.format(hasattr(Student, 'info')))
print('Student有属性func: {}'.format(hasattr(Student, 'func')))
print('Student有属性__init__: {}'.format(hasattr(Student, '__init__')))
print('Student有属性reInitInfo: {}'.format(hasattr(Student, 'reInitInfo')))
print('Student有属性name: {}'.format(hasattr(Student, 'name')))
print('Student有属性mobile: {}'.format(hasattr(Student, 'mobile')))
print("**********************************************************")
# 实例属性确定
print('stu有属性classText: {}'.format(hasattr(stu, 'classText')))
print('stu有属性info: {}'.format(hasattr(stu, 'info')))
print('stu有属性func: {}'.format(hasattr(stu, 'func')))
print('stu有属性__init__: {}'.format(hasattr(stu, '__init__')))
print('stu有属性reInitInfo: {}'.format(hasattr(stu, 'reInitInfo')))
print('stu有属性name: {}'.format(hasattr(stu, 'name')))
print('stu有属性mobile: {}'.format(hasattr(stu, 'mobile')))
***结果:***
Student有属性classText: True
Student有属性info: True
Student有属性func: True
Student有属性__init__: True
Student有属性reInitInfo: True
Student有属性name: False
Student有属性mobile: False
**********************************************************
stu有属性classText: True
stu有属性info: True
stu有属性func: True
stu有属性__init__: True
stu有属性reInitInfo: True
stu有属性name: True
stu有属性mobile: True
[Finished in 0.0s]