Ini mungkin agak terlambat tapi saya membuat solusi menggunakan Python Meta-Classes (versi dekorator di bawah ini juga).
Ketika __init__
dipanggil pada saat run time, ia mengambil setiap argumen dan nilainya dan menetapkannya sebagai variabel instan ke kelas Anda. Dengan cara ini Anda bisa membuat kelas struct-like tanpa harus menetapkan setiap nilai secara manual.
Contoh saya tidak memiliki pengecekan kesalahan sehingga lebih mudah diikuti.
class MyStruct(type):
def __call__(cls, *args, **kwargs):
names = cls.__init__.func_code.co_varnames[1:]
self = type.__call__(cls, *args, **kwargs)
for name, value in zip(names, args):
setattr(self , name, value)
for name, value in kwargs.iteritems():
setattr(self , name, value)
return self
Ini dia beraksi.
>>> class MyClass(object):
__metaclass__ = MyStruct
def __init__(self, a, b, c):
pass
>>> my_instance = MyClass(1, 2, 3)
>>> my_instance.a
1
>>>
Saya diposting di reddit dan / u / matchu memposting versi dekorator yang lebih bersih. Saya mendorong Anda untuk menggunakannya kecuali jika Anda ingin memperluas versi metaclass.
>>> def init_all_args(fn):
@wraps(fn)
def wrapped_init(self, *args, **kwargs):
names = fn.func_code.co_varnames[1:]
for name, value in zip(names, args):
setattr(self, name, value)
for name, value in kwargs.iteritems():
setattr(self, name, value)
return wrapped_init
>>> class Test(object):
@init_all_args
def __init__(self, a, b):
pass
>>> a = Test(1, 2)
>>> a.a
1
>>>