gpt4 book ai didi

Pythonic 替代 dict-style setter?

转载 作者:太空宇宙 更新时间:2023-11-04 10:36:44 25 4
gpt4 key购买 nike

人们倾向于认为 getter 和 setter 不是 Python 式的,而是更喜欢使用 @property。我目前正在尝试扩展一个使用 @property 来支持字典的类的功能:

class OldMyClass(object):
@property
def foo(self):
return self._foo

@foo.setter
def foo(self, value):
self.side_effect(value)
self._foo = value

class NewMyClass(object):
@property
def foo(self, key): # Invalid Python
return self._foo[key]

@foo.setter
def foo(self, key, value): # Invalid Python
self.side_effect(key, value)
self._foo[key] = value

当然,我可以创建一些辅助类来处理这个问题,但似乎只编写带有键和值的 setter/getter 函数会简单得多。但是有没有更 Pythonic 的方法来进行这种重构?

最佳答案

您所描述的不是属性的情况。属性用于允许 obj(或者更确切地说,它的类)自定义 obj.prop = value 的行为。如果你想自定义obj.prop[key] = value,那么你需要在obj.prop而不是obj中处理它,这意味着您需要将 obj.prop 设为自定义类。您在这里想要的是创建一个带有 __setitem__ 的自定义类。

class Foo(object):
def __init__(self):
self._vals = {}

def __setitem__(self, key, val):
do_side_effect(key, val)
self._vals[key] = val

然后在您的 MyClass 的 __init__ 中,执行 self.foo = Foo()

如果你想让这个类似字典的对象知道它的父对象是什么(例如,因为副作用应该发生在父对象上,那么将父对象作为参数传递给 Foo:

class Foo(object):
def __init__(self, parent):
self.parent = parent
self._vals = {}

def __setitem__(self, key, val):
parent.do_side_effect(key, val)
self._vals[key] = val

然后在 MyClass.__init__ 中执行 self.foo = Foo(self)

关于 getter/setter,您正在做的不是典型的 getter/setter。不鼓励的事情是像 getSomeProp()setSomeProp(value) 这样的事情,其中​​对于您获取/设置的每个属性都有一个单独的方法。在您的示例中,您描述的是不同的东西,这是用于设置键值对的通用获取/设置机制(这可能对对象的行为有一定意义)。拥有一个方法 setPair(key, value) 并不比拥有一个名为 doSomething(arg1, arg2) 的方法差。这里有一个额外的参数,因此您的任务不符合 obj.key = value 的简单模式。如果您希望 obj.prop[key] = value 中的键/值“了解”obj,您还有一个额外的间接层;在像 obj.prop[key] = value 这样的赋值中,键和值是从 obj 中删除的一步,并且只与 prop 直接交互.

您也可以使用 John Smith Optional 建议的简单方法来完成。您是想那样做还是像我描述的那样使用自定义对象取决于您希望如何设置 API。围绕自定义“数据保存”类构建代码(如我在此处概述的类)可以提高可读性,但它确实使实现变得有点复杂。

关于Pythonic 替代 dict-style setter?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22900940/

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