我经常在重写子类中的方法时这样做:defmethod_x(self):x=super(type(self),self).method_x()[Someextracode]returnx我的问题是:super(type(self),self)有捷径吗? 最佳答案 不要那样做:如果super可以只使用type(self)作为它的第一个参数,那么它就不会被写成在第一名。您必须在此处传递实际类,而不是表达式,如果类已被子类化,表达式可能会发生变化。super的第一个参数需要是包含当前方法定义的类,因为您要告诉super在碱基列表中的何处开始
我的changepassword表单有一些问题,它继续给我同样的错误:super(type,obj):objmustbeaninstanceorsubtypeoftype这是我的表格:classPasswordChangeForm(forms.Form):current_password=forms.CharField(label=u'CurrentPassword',widget=forms.PasswordInput(render_value=False))new_password=forms.CharField(label=u'NewPassword',widget=forms.
在下面的示例中,B.Go()方法的最后两行都调用了classA中的Go()方法>。它们在功能上是否相同?使用super()的唯一好处是我不必知道继承的类名吗?classA(object):defGo(self):print"CallingA.Go()"classB(A):defGo(self):super(B,self).Go()A.Go(self)inst=B()inst.Go() 最佳答案 不,super()做一些直接调用A.Go不能的事情。super(B,self).Go()调用方法解析顺序中的下一个方法。如果B根本没有实现该
我知道__new__是一个静态方法,可以从中调用super()创建一个新对象,如下所示:>>>classA:...def__new__(cls):...print('__new__called')...returnsuper().__new__(cls)...>>>a=A()__new__called为什么super调用不能与其他静态方法一起使用?为什么以下会失败?>>>classB:...@staticmethod...deffuncB():...print('funcBcalled')...>>>classC(B):...@staticmethod...deffuncC():...
classWorks(type):def__new__(cls,*args,**kwargs):print([cls,args])#outputs[,()]returnsuper().__new__(cls,args)classDoesNotWork(type):def__new__(*args,**kwargs):print([args[0],args[:0]])#outputs[,()]returnsuper().__new__(args[0],args[:0])Works()#isfineDoesNotWork()#gets"RuntimeError:super():noargu
我在使用pip使用默认的clang编译器编译mapscript(是来自pypi的包含C代码的包)时遇到了一些问题。这是我的尝试:-$sudopipinstallmapscriptPassword:Downloading/unpackingmapscriptRunningsetup.pyegg_infoforpackagemapscriptRequirementalreadysatisfied(use--upgradetoupgrade):distributein/opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib
我无法在Ubuntu上安装基本的Django包。我刚刚删除了virtualenv并重新制作了它。pip3install=pip3install-rrequirements.txt[mything]cchilders@cchilders-desktop:~/projects/mything(master)$catrequirements.txtDjango==1.10.1django-filterdjangorestframeworkpsycopg2twilioipdbipython[mything]cchilders@cchilders-desktop:~/projects/mythi
根据http://docs.python.org/2/library/functions.html#super,Ifthesecondargumentisomitted,thesuperobjectreturnedisunbound.哪个是super(类型)。我想知道什么是无界的,什么时候是有界的。 最佳答案 您问题的其他答案(answer、answer)已经解释了绑定(bind)/未绑定(bind)这两个词的含义。Somyfocusistoexplainonlytheuseofanunboundproxyobjectreturne
我正在使用Flask创建模块化应用blueprints特征。结果,我的目录结构是这样的:project__init__.pyconfig.pymould.pymodules__init__.pycore__init__.pycore.pydb.pymodels.py不要将此处的模块目录与Python模块混淆,它们用于为我的项目提供模块化结构(核心模块、foo模块、bar模块等)。现在,模块目录中的每个文件夹(以及其中的同名模块,例如core.core)都动态导入到我的主flask应用程序(mould.py)中这样做:foriteminos.listdir("modules"):ifno
作为root用户,我看到:root@5d6f29f1d4e9:/usr/local/lib/python2.7#ls-a...dist-packagessite-packagesroot@5d6f29f1d4e9:/usr/local/lib/python3.6#ls-a...dist-packages当我运行这个时:find/-typed-name'site-packages'唯一的结果是:/usr/local/lib/python2.7/site-packages有谁知道为什么我在3.6中看不到站点包?我安装了python3:aptinstall-ybuild-essentiall