1.反射
# author:wei
class Foo(object):
def __init__(self,name):
self.name=name
def func(self):
return 'ok'
obj=Foo('为')
# ret=getattr(obj,input('name'))
# //获取成员,第一个参数是对象名,第二个参数是字符串
# 这个字符串是成员名,这里是函数名
# print(ret())
# print(hasattr(obj,input('name')))
# 检查成员
#这里是判断,如果字符串是成员中的一个,hasattr()返回的是一个true(是bool)
# print(obj.name)
# 设置成员
# setattr(obj,'name',input('the name you define'))
#这里改变了属性的值
# print(obj.name)
# 删除成员
# print(obj.name)
# delattr(obj,'name')//删除了obj.name这个属性
# print(obj.name)
2.属性方法
# author:wei
class Dog(object):
def __init__(self,name):
self.name=name
self.__food=None
@property
def eat(self):
print('%s is eating %s'%(self.name,self.__food))
@eat.setter
def eat(self,food):
self.__food=food
@eat.deleter
def eat(self):
del self.__food
print('删完了')
d=Dog('GOU')
d.eat='dfdsf'
d.eat
# 变成属性方法后就不是一个函数了
3.类方法
d.name='xiao_gou'
# author:wei
# 类方法:只能访问类变量,不能访问实例变量
# class Dog(object):
# def __init__(self,name):
# self.name=name
# @classmethod
#
# def eat(self):
# print('%s is eating'%self.name)
# d=Dog('为')
# d.eat()
# 这里报错是因为类方法不能访问实例变量
class Dog(object):
name=111
def __init__(self,name):
self.name=name
@classmethod
def eat(self):
print('%s is eating'%self.name)
d=Dog('为')
# 这里加上一个类变量就不会报错了
4.类方法
# author:wei
# 静态方法
class Dog(object):
def __init__(self,name):
self.name=name
@staticmethod
def eat(self):
print('%s is eating'%self.name)
s=Dog('fdf')
s.eat()
# 上面的调用会出以下错误,说是eat需要一个self参数,
# 但调用时却没有传递,没错,当eat变成静态方法后,
# 再通过实例调用时就不会自动把实例本身当作一个参数传给self了
#1. 调用时主动传递实例本身给eat方法,即d.eat(d)
# 2. 在eat方法中去掉self参数,但这也意味着,
# 在eat中不能通过self.调用实例中的其它变量了
#