- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
上下文:我想在我没有创建的对象上使用 heapq(以及其他任何东西),这些对象本身没有 __lt__
运算符。我可以吗? (没有包装类)。
类(class):
class Node:
def __init__(self, val):
self.val = val
现在,在解释器的运行时,我得到了一些对象集合。我想遍历它们,添加一个 dunder 方法(在我的例子中是 lt),例如:
n = Node(4)
m = Node(5)
def myLT(self, other):
return self.val < other.val
我尝试过的:
n.__lt__ = types.MethodType(myLT, n)
m.__lt__ = types.MethodType(myLT, m)
还有
n.__lt__ = types.MethodType(myLT, n)
m.__lt__ = types.MethodType(myLT, n)
(如果绑定(bind)相同的仿函数会改善问题)
>>> n < m
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: '<' not supported between instances of 'Node' and 'Node'
虽然:
>>> n.__lt__(m)
True
我可以使用包装类,这在某些方面很糟糕(额外的内存和遍历代码变得更丑陋,但至少保持原始对象不变):
class NodeWrapper:
def __init__(self, n):
self.node = n
def __lt__(self):
return self.node.val
我只是想知道我在添加 dunder 方法时是否做错了什么,或者这在 python 3.x 中是否不起作用。如果重要的话,我正在使用 3.6.9。
最佳答案
您可以尝试通过更改实例的 __class__
属性来对 dunder 进行 monkeypatching。如文档部分所述 Special method lookup :
For custom classes, implicit invocations of special methods are onlyguaranteed to work correctly if defined on an object’s type, not inthe object’s instance dictionary.
def patch_call(instance, func, memo={}):
if type(instance) not in memo:
class _(type(instance)):
def __lt__(self, *arg, **kwargs):
return func(self, *arg, **kwargs)
memo[type(instance)] = _
instance.__class__ = memo[type(instance)]
patch_call(m, myLT)
patch_call(n, myLT)
n < m
# True
感谢@juanpa.arrivilaga 建议缓存类以提高性能。
关于python - 如何将 dunder 方法 monkeypatch 到现有实例?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65456318/
我正在尝试使用 pytest 测试一些代码,并且需要更改某个模块中的函数。我的一个导入也导入了该函数,但是当我使用 monkeypatch 更改方法时,此操作失败。这是我所拥有的: util.py d
我正在尝试使用 monkeypatch 来模拟一个公共(public)函数,但它似乎对我不起作用。 这是我的文件结构 myproject |-mrss |- feed_burner.py
我想知道是否有人可以解释并提供解决此问题的方法: $ cat object-override-methods.py class A: def foo(self): return
我有一些愚蠢的代码,其中包含猴子匹配部分。以下示例仅供自学,不用于生产。 class MyClass: def some_method(self): print("some_m
大家好, 我正在使用 sympy 进行研究,发现自己写了很多像 Integer(1)/k 这样的东西(实际上,这已经是 Integer(1)/Integer( k)). 我想知道是否有一种方法可以将
来自大学的建议和关注this answer 我正在尝试对 res.send 进行猴子修补,但出现以下错误: TypeError: Cannot read property 'req' of undef
在nodev4上运行 - 假设我有 2 个库:foo 和 bar foo 有这个 var bar = require('./lib/bar'); exports = module.exports =
我正在通过请求的 Session 类在 python 中访问 API。我正在使用 requests.Session() 进行 GET 和 POST 方法调用。 在每次调用(GET/POST)失败时,我
灵感来自 "Define @property on function" ,我试图覆盖函数的命名空间: >>> class MyDict(dict): ... def __getitem__(s
我正在 pytest 中使用 Monkeypatch 固定装置,试图模拟终端窗口的当前大小。 import os import pytest def get_terminal_size():
我正在尝试对我使用的外部模块中的函数进行 Monkeypatch,但 Monkeypatch 似乎无法访问该函数,因为模块的命名空间在导入时被覆盖。 具体来说,我使用 Bio.PDB.PDBList.
我正在尝试在pytest和monkeypatching的帮助下模拟我正在调用的函数的返回值。 我为我的模拟类设置了固定装置,并且我正在尝试“覆盖”所述类中的方法之一。 from foggycam im
我知道这是一个疯狂的黑客行为,但无论如何我对此感到好奇。我们的环境的系统时间错误,我们无法将其设置为正确的时间。它是专用硬件,因此我们无法更改系统时间。不过,我们确实有一项服务可以为我们提供正确的当前
我的网络应用程序的主 JavaScript 中有以下代码: // uniq for arrays if (!Array.prototype.getUnique) { Array.pro
我已经阅读了我能找到的所有其他相关答案,但没有一个有效。本质上,我想制作这个来源: https://github.com/gildas-lormeau/zip.js/blob/master/WebCo
我正在练习 TDD,而且我对此还很陌生。在我的测试用例中,我想从 stdin 读取并检查输出是否与输入匹配。 对于stdin,我想使用模拟对象。因此我使用 monkeypatch.setattr('s
我想测试一个函数的默认行为。我有以下内容: # app/foo.py DEFAULT_VALUE = 'hello' def bar(text=DEFAULT_VALUE): print(te
给定一个类 A 我可以简单地通过 a 添加一个实例方法 def a(self): pass A.a = a 但是,如果我尝试添加另一个类 B 的实例方法 b,即 A.b = B.b,尝试调用
我想用 monkeypatch 一个 Vagrant 插件。 由于我不是 Ruby 专家,但想测试一些行为,所以我需要一些帮助。 我需要重写 chef_provisioner? 方法: https:/
我是一名 Ruby 程序员。对我来说,monkeypatching 是在运行时更改外部项目中的类或模块方法。我感兴趣的是,您有什么机制可以保护您免受某些滥用该优良特性的影响。以下是我遇到的一些场景,其
我是一名优秀的程序员,十分优秀!