如果你在变量中保存对super的调用以备将来使用,会发生什么?

如果我对这里显而易见的事情一无所知,请原谅我,但是如果你在变量中保存对super的调用并稍后使用它会发生什么.

这是类定义的一部分,向您展示我的意思.

class CaselessDict(dict):

    def __init__(self,*args,**kwargs):
        self.super = super(CaselessDict,self) # save super
        self.update(*args,**kwargs)

    def __getitem__(self,key):
        key = self.parsekey(key)
        return self.super.__getitem__(key) # use saved super

当我实现这个CaselessDict类时几乎每个方法都有超级的东西.

最佳答案
预期的事情发生了:self.super将只保存一个超级对象,就像super(CaselessDict,self)一样.

这种方法的问题是每个实例只有一个超级属性,所以如果你有更多的类可以使用这种技术,那么只有分配给super last的那个才能正常运行.哎哟!所以,这样做通常不是一个好主意.你可以将属性命名为__super,因此它会被破坏,但我建议只调用super(CaselessDict,self),就像其他人一样.

当然,Python 3中的草更环保,普通的super()调用就足够了.

相关文章

在这篇文章中,我们深入学习了XPath作为一种常见的网络爬虫技巧。XPath是一种用于定位和选择XML文档中特...
祝福大家龙年快乐!愿你们的生活像龙一样充满力量和勇气,愿你们在新的一年里,追逐梦想,勇往直前,不...
今天在爬虫实战中,除了正常爬取网页数据外,我们还添加了一个下载功能,主要任务是爬取小说并将其下载...
完美收官,本文是爬虫实战的最后一章了,所以尽管本文着重呈现爬虫实战,但其中有一大部分内容专注于数...
JSON是一种流行的数据传输格式,Python中有多种处理JSON的方式。官方的json库是最常用的,它提供了简单...
独立样本T检验适用于比较两组独立样本的均值差异,而配对T检验则适用于比较同一组样本在不同条件下的均...