gpt4 book ai didi

python - 以编程方式设置属性

转载 作者:行者123 更新时间:2023-11-28 21:26:52 24 4
gpt4 key购买 nike

问题

我想完成以下任务:

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.__dict__ 进行调整,例如像这样:

for i in [["A", 0], ["B", 1], ["C", 2]]:
tmp = do_stuff(tmp2[i[1]])
if tmp != None: inst.__dict__[i[0]] = tmp

然而,由于 ABC 是属性,这个计划被挫败了。

类似 LISP 的宏在这里会是一个巨大的帮助,不幸的是 Python 似乎不支持宏而且我不想将依赖项添加到我在网上找到的 Python 宏库之一(我没有'测试,因为无论如何我都无法使用它们)。

我还想避免在列表中使用匿名函数,因为这可能会产生与第二个代码 list 中相同数量的代码。

目前我解决这个问题的最后手段是 eval,我想不惜一切代价避免这种情况。

最佳答案

您正在寻找setattr() :

for i in [["A", 0], ["B", 1], ["C", 2]]:
tmp = do_stuff(tmp2[i[1]])
if tmp != None: setattr(inst, i[0], tmp)

引用文档:

This is the counterpart of getattr(). The arguments are an object, a string and an arbitrary value. The string may name an existing attribute or a new attribute. The function assigns the value to the attribute, provided the object allows it. For example, setattr(x, 'foobar', 123) is equivalent to x.foobar = 123.

请注意,由于 None 是 python 中的单例,通常使用 isis 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)

PEP 8 python styleguide不鼓励复合语句;将 if 套件单独占一行,即使它只有一行。

关于python - 以编程方式设置属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12122838/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com