- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我无法覆盖 Python2.7 中的某些内置函数,例如“__setitem__”(尽管在我测试的以前的版本中也会出现同样的情况)
虽然我知道这很容易通过子类化来实现,但这不是我想要的,我需要能够动态覆盖这些方法。
显然,当我的类是“object”的子类时,重写的方法总是以调用原始方法结束,但当我的类不是“object”时',它有效:
>>> def new_implementation(k, v):
... print 'New implementation'
...
### class that extends object
>>> class ExtendsObject(object):
... def __setitem__(self, k, v):
... print 'ExtendsObject implementation'
...
### Checking implementation
>>> obj = ExtendsObject()
>>> obj[0]=0
ExtendsObject implementation
### trying to override setitem, no success
>>> obj.__setitem__ = new_implementation
>>> obj[0]=0
ExtendsObject implementation
### class that does NOT extends object
>>> class DoesNotExtend:
... def __setitem__(self, k, v):
... print 'DoesNotExtend implementation'
...
### Checking implementation
>>> obj_2 = DoesNotExtend()
>>> obj_2[0]=0
DoesNotExtend implementation
### overriding now works!
>>> obj_2.__setitem__ = new_implementation
>>> obj_2[0]=0
New implementation
出于某种原因,对象似乎对这些内置函数使用了一些不同的方法解析顺序。
这是一个错误吗?我做错了什么吗?
最佳答案
对于旧式类,每次需要时都会在实例上查找特殊方法。新型类仅在实例的类型 中查找特殊方法,而不是在实例的字典本身中查找 - 这就是您看到所看到的行为的原因。
(如果您不知道——新式类是直接或间接派生自 object
的类。)
关于python - 如何动态覆盖__setitem__? (没有子类),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9281451/
我希望能够拦截函数内的变量赋值并执行自定义代码。我试过如下创建自定义字典: class userdict(dict): def __setitem__(self, key, value):
我正在尝试创建一个将数据存储在本地缓冲区中并充当数据库接口(interface)的类。我有以下代码: class Table(object): def __init__(self, ta
我在第 3 方模块中找到了这段代码,在这种情况下,该模块忽略了 foo[::step] 或 key.step。 def __getitem__(self, key): if isinstanc
我正在运行 Python 2.7.10。 我需要拦截列表中的更改。 “更改”是指任何在浅层意义上修改列表的内容(如果列表由相同顺序的相同对象组成,则列表不会更改,而不管这些对象的状态如何;否则,它是)
我有以下字典: class Only5Items(dict): def __setitem__(self, key, value): if len(self) < 5:
这是我所做的,尝试为类似 dict 的数据库创建一个包装器,以及其他功能: class database(object): def __init__(self, name):
我不想在使用 __setitem__ 时测试键的类型。但奇怪的是,我发现使用多个键时,部分代码被省略了。这是我的测试类: class foo(): def __init__(self):
我有一个 list 的子类这在列表的组件上添加了一些管理内容。一切正常,但 mypy投诉 super 的签名调用 __setitem__ . 这是问题减少到最低限度: from typing impo
在下面的示例中,如果通过 = 设置数据,则有一个具有 __setitem__ 方法的类可以正常工作。但是,如果例如 list 类型的数据是使用 .append 方法隐式设置的,则不会调用 __seti
在下面的示例中,如果通过 = 设置数据,则有一个具有 __setitem__ 方法的类可以正常工作。但是,如果例如 list 类型的数据是使用 .append 方法隐式设置的,则不会调用 __seti
如果你这样做 import gdbm db = gdbm.open('foo', 'cs') 你得到一个对象: 您现在可以通过以下方式在数据库中设置键和值: db['foo'] = 'bar' pr
我有以下类(class): class autoArray2(numpy.ndarray): def __new__(self, *args, **kwargs): obj =
我有以下代码: class VectorN(object): def __init__(self, param): if isinstance(param, int):
我正在构建一个子类 dict 并覆盖 __setitem__ 的类。我想确定在所有可能设置字典项的情况下都会调用我的方法。 我发现了三种情况,Python(本例中为 2.6.4)在设置值时不调用我重写
我试图实现一个(原型(prototype),而不是生产)版本的持久字典,它使用磁盘上的pickle作为持久存储。但是,pickle.load 出于自身目的调用 __setitem__ ,并且(当然)会
基于Paul's answer ,我尝试运行以下冒泡排序算法,该算法使用 slice 和 __setitem__ 方法;我确信有一些简单的事情我做得不对,不确定那可能是什么? 代码 def bubbl
在下面的语句中定义一个类的行为: my_object[item] = ... 我知道我需要定义 __setitem__ 方法。 下面的语句需要定义什么方法: my_object[item] += ..
谁能告诉我为什么这段代码提示容器上没有 __setitem__?我以为我只需要容器上的 __getitem__ 来获取项目,然后 __iadd__ 来设置值,不知道为什么它期待 __setitem__
我正在开发一个自定义类来使用 Python 处理矩阵。我遇到了一个问题,我的测试程序显然没有向我的 __setitem__ 方法传递足够的参数。这是代码: def __setitem__(self,
var obj = {} obj.__setitem__ = function(key, value){ this[key] = value * value } obj.x = 2 // 4 o
我是一名优秀的程序员,十分优秀!