Python中文
首页
教程
问答
标签
搜索
登录
注册
Duck类型,isinstance(),\uU子类钩子函数重写,以及types.MethodType()一起工作?
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我在一个项目中有一个类,它根据初始化时的条件实现一组动态绑定方法。这样做的目的是通过创建一个包含一系列绑定到对象的方法的新模块,使库的功能易于扩展,同时也简化了库的API,使之不积极参与其中。在</p> <p>这不是一个完美的并行,但是为了表示这一点,我将使用一个<code>Dog</code>类,该类在初始化时从tricks模块获取一系列技巧,在本例中,它将作为包含模块名称的字符串传递。在</p> <pre><code>class Dog(object): def __init__(self, name, module_name): self.name = name # imports module module = __import__("mylib.tricks.{mod}".format(mod=module_name), from_list=['arbitrary argument']) # Dog object gets all tricks from module as bound methods tricks = module.__all__ for trick in tricks: exec("self." + trick + "=types.MethodType(" + trick + ", self)") </code></pre> <p>然后,由于这些方法将被指定为绑定方法,因此tricks模块可以包含访问类属性的方法,例如:</p> ^{pr2}$ <p>现在我终于到了我挣扎的那部分了。使用<code>ABCMeta</code>类<code>__subclasshook__</code>方法可以更改is <code>instance()</code>方法的行为,以便它为实现特定方法的任何类返回true。例如,我们可以有一个<code>DuckABC</code>抽象基类,它本质上是一个接口,对于实现<code>quack()</code>方法的任何类也返回true。在</p> <pre><code>class DuckABC: __metaclass__=ABCMeta @abstractmethod def quack(self): pass @classmethod def __subclasshook__(cls, instance): if cls is DuckABC: if any("quack" in class_.__dict__ for class_ in instance.__mro__): return True return NotImplemented class Cat(object): def __init__(self, name): self.name=name def quack(self): # Not a very talented cat print 'meow' >>> my_cat = Cat('Tom') >>> isinstance(my_cat, DuckABC) True </code></pre> <p>然而,这就是我的问题所在。使用这个<code>DuckABC</code>抽象基类和上面定义的动态<code>Dog</code>类,以下情况是正确的:</p> <pre><code>>>> my_dog = Dog('Berkley', 'name_of_module_containing_quack') >>> my_dog.quack() Quack! >>> isinstance(my_dog, DuckABC) False </code></pre> <p>我理解它没有返回true,因为<code>Dog</code>类本身没有任何称为<code>quack</code>的方法,尽管{<cd1>}类的这个特定实例学会了如何嘎嘎叫。在</p> <p>所以我的问题是:在这个框架中有没有任何方法可以使用<code>isinstance()</code>方法来检查我的dog类的特定实例是否知道如何嘎嘎作响?如果没有,我还有什么选择可以实现相同的功能?在</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>使用<code>hasattr</code>:</p> <pre><code>if hasattr(dog, "Quack"): dog.Quack() else: dog.Sit() </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
为什么在使用strptime时会出现未进行转换的数据错误?
9 回答
为什么在使用strptim时会出现这个datetime日期错误
3 回答
为什么在使用StyleFrame时索引列的标题不显示sf.至excel()?
5 回答
为什么在使用sum()函数时会发生“int”对象不可调用的错误?
4 回答
为什么在使用sympy.dsolve时会得到“'list'对象没有属性'func'”?
8 回答
为什么在使用tabla时会得到一个空的数据帧?
3 回答
为什么在使用tensorboard时需要add_graph()的第二个参数?
6 回答
为什么在使用TensorFlow Lite转换YOLOv4时,推断时间/大小没有改进?有什么可能的改进吗?
8 回答
为什么在使用Tensorflow加载训练批时会出现内存泄漏?
4 回答
为什么在使用tensorflow时会收到警告/错误(使用函数API,但未实现错误)
7 回答
为什么在使用tetpyclient发出POST请求时出现403错误?
6 回答
为什么在使用TextBlob时会出现HTTP错误?
2 回答
为什么在使用TFIDF时出现错误“IndexError:list index out of range”pyspark.ml.feature?
1 回答
为什么在使用timedelta格式化之后,我在python中的日期是错误的?
8 回答
为什么在使用timeit或exec函数时,函数中的变量不会在提供的全局命名空间中搜索?
4 回答
为什么在使用tkinter时不能使用复选框?
1 回答
为什么在使用todoistpythonapi时会返回这个奇怪的ID?
7 回答
为什么在使用TQM时,在调整图像大小时,处理时间会有很大的差异?
5 回答
为什么在使用Tweepy下载用户时间线时收到错误消息
1 回答
为什么在使用twitter帐户登录Django应用程序时重定向127.0.0.1:8000?
4 回答