技术背景
当我们在Python中写一个class时,如果有一部分的成员变量需要用一个字典来命名和赋值,此时应该如何操作呢?这个场景最常见于从一个文件(比如json、npz之类的文件)中读取字典变量到内存当中,再赋值给一个类的成员变量,或者已经生成的实例变量。
使用__dict__定义成员变量
在python中直接支持了__dict__.update()
这样的方法来操作,避免了对locals()、vars()和eval()函数的使用,我们可以直接看这样的一个案例:
In [1]: dict_a = {'a':1, 'b':2} In [2]: dict_b = {'c':3} In [3]: class D(object): ...: def __init__(self): ...: self.d = 4 ...: self.__dict__.update(dict_a) ...: self.__dict__.update(dict_b) ...: In [4]: new_D = D() In [5]: new_D.__dict__ Out[5]: {'d': 4, 'a': 1, 'b': 2, 'c': 3} In [6]: new_D.a Out[6]: 1 In [7]: new_D.c Out[7]: 3
在这个案例中,我们在类的外部定义了两个字典dict_a
和dict_b
,字典的key值都是字符串的格式。而我们知道字符串格式在python中如果不使用eval,是不能直接作为变量名来使用的。而通过__dict__.update()