请注意
class Foo(object):
a = None
在Foo的字典中设置一个键值对:
Foo.__dict__['a']=None
同时
def __init__(self, a = None, b = None, c = None):
self.a = a
在 Foo 实例对象的字典中设置一个键值对:
foo=Foo()
foo.__dict__['a']=a
因此,在定义的顶部设置类成员与在定义的下半部分(__init__ 内)设置实例属性没有直接关系。
另外,很高兴知道__init__ 是Python 的初始化程序。 __new__ 是类构造函数。
如果您正在寻找一种基于__init__ 的参数自动添加一些实例属性的方法,您可以使用这个:
import inspect
import functools
def autoargs(*include,**kwargs):
def _autoargs(func):
attrs,varargs,varkw,defaults=inspect.getargspec(func)
def sieve(attr):
if kwargs and attr in kwargs['exclude']: return False
if not include or attr in include: return True
else: return False
@functools.wraps(func)
def wrapper(self,*args,**kwargs):
# handle default values
for attr,val in zip(reversed(attrs),reversed(defaults)):
if sieve(attr): setattr(self, attr, val)
# handle positional arguments
positional_attrs=attrs[1:]
for attr,val in zip(positional_attrs,args):
if sieve(attr): setattr(self, attr, val)
# handle varargs
if varargs:
remaining_args=args[len(positional_attrs):]
if sieve(varargs): setattr(self, varargs, remaining_args)
# handle varkw
if kwargs:
for attr,val in kwargs.iteritems():
if sieve(attr): setattr(self,attr,val)
return func(self,*args,**kwargs)
return wrapper
return _autoargs
所以当你说
class Foo(object):
@autoargs()
def __init__(self,x,path,debug=False,*args,**kw):
pass
foo=Foo('bar','/tmp',True, 100, 101,verbose=True)
你会自动获得这些实例属性:
print(foo.x)
# bar
print(foo.path)
# /tmp
print(foo.debug)
# True
print(foo.args)
# (100, 101)
print(foo.verbose)
# True
附言。虽然我写了这个(为了好玩),但我不建议将autoargs 用于严肃的工作。明确是简单、清晰和无误的。我不能对autoargs说同样的话。
PPS。只是我,还是 Stackoverflow 上有很多按钮坏了?编辑器窗口丢失了所有图标... :(清除浏览器缓存解决了问题。