- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我希望使属性不区分大小写。但是覆盖 __getattr__
和 __setattr__
有点不同,如以下玩具示例所示:
class A(object):
x = 10
def __getattr__(self, attribute):
return getattr(self, attribute.lower())
## following alternatives don't work ##
# def __getattr__(self, attribute):
# return self.__getattr__(attribute.lower())
# def __getattr__(self, attribute):
# return super().__getattr__(attribute.lower())
def __setattr__(self, attribute, value):
return super().__setattr__(attribute.lower(), value)
## following alternative doesn't work ##
# def __setattr__(self, attribute, value):
# return setattr(self, attribute.lower(), value)
a = A()
print(a.x) ## output is 10
a.X = 2
print(a.X) ## output is 2
我对两点感到困惑。
getattr()
是 __getattr__
的语法糖,但它们的行为不同。__setattr__
需要调用 super()
,而 __getattr__
不需要?最佳答案
I assume
getattr()
is a syntactic sugar for__getattr__
, but they behave differently.
那是因为假设不正确。 getattr()
经历了整个属性查找过程,其中__getattr__
只是一部分。
属性查找首先调用一个不同的 钩子(Hook),即 __getattribute__
method ,默认情况下通过实例字典和类层次结构执行熟悉的搜索。 __getattr__
仅当 __getattribute__
未找到该属性时才会调用.来自 __getattr__
documentation :
Called when the default attribute access fails with an
AttributeError
(either__getattribute__()
raises anAttributeError
because name is not an instance attribute or an attribute in the class tree forself
; or__get__()
of a name property raisesAttributeError
).
换句话说,__getattr__
是一个额外 钩子(Hook),用于访问不存在的属性,否则会引发 AttributeError
.
此外,功能如 getattr()
或 len()
不是 dunder 方法的语法糖。他们几乎总是做更多的工作,dunder 方法是一个钩子(Hook),供该进程调用。有时会涉及到多个钩子(Hook),例如这里,或者通过调用类来创建类的实例时。有时连接相当直接,例如 len()
,但即使在简单的情况下,也会进行钩子(Hook)本身不负责的额外检查。
Why does
__setattr__
need to callsuper()
, while__getattr__
doesn't?
__getattr__
是一个可选 钩子(Hook)。没有默认实现,这就是为什么 super().__getattr__()
不起作用。 __setattr__
不是可选的,所以 object
为您提供默认实现。
请注意,通过使用 getattr()
你创造了一个无限循环! instance.non_existing
会调用__getattribute__('non_existing')
然后 __getattr__('non_existing')
, 此时您使用 getattr(..., 'non_existing')
这叫__getattribute__()
然后 __getattr__
等
在这种情况下,您应该覆盖 __getattribute__
相反:
class A(object):
x = 10
def __getattribute__(self, attribute):
return super().__getattribute__(attribute.lower())
def __setattr__(self, attribute, value):
return super().__setattr__(attribute.lower(), value)
关于python - 覆盖 getattr 和 setattr 的方式的根本区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51270662/
如果我使用 setattr(p,'wrong_attr','value') 而不是 p=MyModel.objects.filter(WRONG_ATTRIBUTE=value) 我没有收到与不存在的
我有一个定义了多个方法的类。 import mat class Klass(object): @mat.sell(mat.CanSet): def method1(self):
我不知所措。 找不到任何其他有助于解决此问题的内容。 dta = {'type': "", 'content': ""} print dta >>>{'content': '', 'type': ''
这就是我的意思: >>> class Foo: pass >>> foo = Foo() >>> setattr(foo, "@%#$%", 10) >>> foo.@%#$% Syn
这个问题已经有答案了: What do lambda function closures capture? (8 个回答) 已关闭 3 年前。 我正在尝试创建一个 class适应django反对导出。
我想了解对象删除在 python 上的工作原理。这是一组非常简单的代码。 class A(object): def __init__(self): setattr(self,
我有一个类(bot),它有一个属性“health”;由于这个类有很多参数,并且我希望用户输入很多参数,所以我选择循环遍历 {param:explanation} 的字典,并为每个参数输入一个要设置的值
我应该将什么作为第一个参数“object”传递给函数 setattr(object, name, value) , 在当前模块上设置变量? 例如: setattr(object, "SOME_CONS
我试图制作一个可以一次性将多个属性分配给不同值的类。因此,我尝试修改 setattr 来执行此操作。 class hello(): def __setattr__(self,attr,valu
我想使用 setattr 更改列的因子水平. However, when the column is selected the standard data.table方式( dt[ , col] ),
为什么在附加或连接对象属性的列表或字典时未调用 __setattr__ 方法。方法描述“在尝试属性分配时调用。”会让我相信连接两个列表是可行的,但是 __setattr__ 方法仍然没有被调用。 cl
我想以编程方式更改类的某些属性。 我发现有setattr函数,但它没有按预期工作。 > obj.setattr('bar', 99) 'MyClass' object has no attribute
我正在创建一个 sigsum() 函数,它使用输入方程和输入变量求和。这是我到目前为止所拥有的: def sigsum(eqn, index, lower=0, upper=None, step=1)
我在 cython 中有一个 cdef 类,我想用 setattr 内置函数初始化它的字段。但是,当我这样做时出现执行错误: /path/.../cimul.cpython-34m.so in cim
我有一个模型类,它有一个引用 django DB 对象的属性。我想使用带有 setattr() 的单个 View 来更改此属性,我用它来更改此对象的任何属性。 问题是,我似乎无法通过堆栈传递对象实例。
我想使用 setattr 创建绘图: import numpy as np import matplotlib.pyplot as plt x = np.random.rand
我试图动态地向类添加方法,但我一直遇到错误,其中 self 未传递给新函数。例如: class Dummy(): def say_hi(self): print("hi") d
我正在编写的一个类需要使用存储 numpy 数组的变量名属性。我想为这些数组的切片赋值。我一直在使用 setattr,这样我就可以让属性名称有所不同。我为切片赋值的尝试是: class Dummy(o
我对 python 还很陌生,但是我需要与一些作为一堆 python 模块编写的软件进行交互(.py 文件,以防我错误地将它们识别为“模块”。)这个程序有一些非常有用的功能以及我确实无法破解的复杂功能
class Product(models.Model): name = models.CharField(max_length=50) desc = models.CharFiel
我是一名优秀的程序员,十分优秀!