Python 以编程方式设置属性 问题:
我想做到以下几点:Python 以编程方式设置属性 问题:,python,properties,setter,Python,Properties,Setter,我想做到以下几点: tmp = do_stuff(tmp2) if tmp != None: num = tmp 但是,我的问题中要分配的变量是对象实例的变量(更好:属性): class mycls(object): def __init__(self): self.__a, self._b, self.c = 2, 3, 5 def set_a(self, val): self.__a = val def set_b(self, val): s
tmp = do_stuff(tmp2)
if tmp != None:
num = tmp
但是,我的问题中要分配的变量是对象实例的变量(更好:属性):
class mycls(object):
def __init__(self):
self.__a, self._b, self.c = 2, 3, 5
def set_a(self, val): self.__a = val
def set_b(self, val): self._b = val
def set_c(self, val): self.c = val
A = property(fset = set_a)
B = property(fset = set_b)
C = property(fset = set_c)
tmp2 = [7, 11, 13]
inst = mycls()
tmp = do_stuff(tmp2[0])
if tmp != None: inst.A = tmp
tmp = do_stuff(tmp2[1])
if tmp != None: inst.B = tmp
tmp = do_stuff(tmp2[2])
if tmp != None: inst.C = tmp
显然,最后一部分看起来非常重复,在我的例子中,需要应用于10多个变量。我现在的问题是:如何压缩最后6行
自己解决问题的尝试
理想情况下,我更喜欢以下解决方案:
for i in [[inst.A, 0], [inst.B, 1], [inst.C, 2]]:
tmp = do_stuff(tmp2[i[1]])
if tmp != None: i[0] = tmp
但是,这不起作用(因为inst.X
是经过计算的,并且不能通过引用/指针存储基本数据类型)。我想出的另一种方法是将变量名用作字符串,并在inst.\uu dict\uuu中摆弄,例如:
for i in [["A", 0], ["B", 1], ["C", 2]]:
tmp = do_stuff(tmp2[i[1]])
if tmp != None: inst.__dict__[i[0]] = tmp
然而,由于A
、B
和C
都是房地产,这一计划失败了
类似LISP的宏在这里将是一个巨大的帮助,不幸的是Python似乎不支持宏,我不想为我在线找到的Python宏库之一添加依赖项(我没有测试,因为我无论如何都不能使用它们)
我还希望避免在列表中使用匿名函数,因为这可能会产生与第二个代码列表中相同数量的代码
我目前解决此问题的最后一个办法是eval
s,我想不惜一切代价避免它。您正在寻找:
要引用文档,请执行以下操作:
这是相对应的。参数是对象、字符串和任意值。该字符串可以命名现有属性或新属性。如果对象允许,函数将值分配给属性。例如,setattr(x,'foobar',123)
相当于x.foobar=123
请注意,由于None
在python中是一个单例,因此通常使用is
或is not
运算符对其进行测试:
for i in [["A", 0], ["B", 1], ["C", 2]]:
tmp = do_stuff(tmp2[i[1]])
if tmp is not None:
setattr(inst, i[0], tmp)
而这些不利于复合陈述;将
if
套件保留在自己的行中,即使它只是一行。为什么不使用lambda函数?@Peter Kirby:我的目标是减少代码量,而不仅仅是将其转换为不同的形式。如果我误解了,请澄清。对不起,我确实误解了。但是,Martjin的答案是正确的,应该可以使用。考虑到styleguide关于缩进的评论:在编写示例代码时,我尽量使其尽可能简短。虽然PEP8中的语句在程序和项目中肯定是最有用的,但我认为这些指导原则并不适用于最少的示例代码;我发现清晰缩进更具可读性,对于示例代码,您希望获得最大可读性。:-)
for i in [["A", 0], ["B", 1], ["C", 2]]:
tmp = do_stuff(tmp2[i[1]])
if tmp is not None:
setattr(inst, i[0], tmp)