我在一些有很多参数(最多20个)的SQLAlchemy ORM类中使用了这样的__init__()。
def __init__(self, **kwargs):
for k, v in kwargs.iteritems():
setattr(self, k, v)像这样设置属性是“pythonic式的”吗?
发布于 2009-04-11 11:04:10
是。另一种方法是。
def __init__(self, **kwargs):
self.__dict__.update( kwargs )发布于 2009-04-13 14:58:49
是的,如果没有更好的方法来提供参数的话。
例如,使用您提到的ORM类,也许允许..
col = Varchar()
col.index = True
col.length = 255..rather than..
col = Varchar(index = True, length = 255)好吧,这不是最好的例子,因为**kwargs方法实际上更好。但我的观点是,在使用像**kwargs这样有时不被鼓励的东西之前,你应该总是考虑实现某些东西的替代方法。
另一件要记住的事情是,您可能会丢失用户期望的行为,例如,如果用户提供了无效的关键字arg,则会引发TypeError,这可以像这样解决。
def __init__(self, **kwargs):
valid_kwargs = ['x', 'y', 'z']
for k, v in kwargs.iteritems():
if k not in valid_kwargs:
raise TypeError("Invalid keyword argument %s" % k)
setattr(self, k, v)最后要考虑的是:
class Hmm:
def __init__(self, **kwargs):
for k, v in kwargs.iteritems():
setattr(self, k, v)
def mymethod(self):
print "mymethod should print this message.."
x = Hmm(mymethod = None)
x.mymethod() # raises TypeError: 'NoneType' object is not callable发布于 2009-04-11 06:49:44
对我来说,如果你只在代码中的一个地方需要它,那么它看起来就像是一条巨蟒。
下面的链接为同样的问题提供了一种更“通用”的方法(例如,使用装饰器和一些额外的功能),请查看:http://code.activestate.com/recipes/551763/
https://stackoverflow.com/questions/739625
复制相似问题