class A(object):
'''describe A'''#描述这个类
def __init__(self,name):
self.name=name
def play(self):
print("playing")
def __call__(self, *args, **kwargs):#类似一种方法,但是这种方法调用需要在实例后加()
print("hello %s",args,kwargs)
def __str__(self):#__str__就是在打印对象是,默认输出该方法的返回时
return "r__str__"
print(A.__doc__)#这个方法就是返回类的描述详细
# __module__表示当前操作的对象在那个模块(也就是从其他路径中导入模块中的类,这条命令能显示路径)
# __class__这个就是和上面差不多都能返回路径,不同的是返回的是带路径的类
f=A("a")
f(1,2,3,name="DOG")#__call__意思就是相当于可以在实例化后面加(),执行call这个方法
print(A.__dict__)#打印类里的所有属性,不包括实例属性
print(f.__dict__)# 通过实例化后调用__dict__ 打印所有的实例属性,不包括类属性
print(f)#打印对象,如果不用__str__方法,就返回<__main__.A object at 0x000001AA225F64A8>,现在返回r__str__
class Foo(object):
def __init__(self):
self.name={}
def __getitem__(self, key):#__可以通过键值对的方式查询(其实本身并没有做什么,只是一种调用方式而已,__setitem__、__delitem_一样)
print("__getitem__",key)
return self.name.get(key)
def __setitem__(self, key, value):#__setitem__可以传入字典进去a2["name"]="gongwei"
print("__setitem__",key,value)
self.name[key]=value
def __delitem__(self, key):#删除,只是说这个是一个删除,但是删不删由里的代码决定
print("__delitem__",key)
a2=Foo()
a2["name"]="gongwei"
print(a2.name)
# print(a2["name"])
#
# del a2["name"]#只是执行了__delitem__,但是并没有删除
#实例的背后是类,那么类背后是什么?
class a(object):
def __init__(self,name):
self.name=name
def tell(self):
print("hello")
f=a("g")
print(type(f))#<class '__main__.a'>
print(type(a))#print(type(a))#
#说明类背后是type
#类有两种创建方法1,普通创建(常用),2,特殊创建
def __init__(self, name):
self.name = name
def tell(self):
print("hello %s"%self.name)
a1=type("a1",(object,),{"__init__":__init__,"tell":tell})
f1=a1("g")
f1.tell()
#类是由type实例化产生的
print(type(type(type)))