猿问

如何将实例成员的默认参数值传递给方法?

如何将实例成员的默认参数值传递给方法?

我想使用实例的属性值将默认参数传递给实例方法:

class C:
    def __init__(self, format):
        self.format = format    def process(self, formatting=self.format):
        print(formatting)

尝试时,我收到以下错误消息:

NameError: name 'self' is not defined

我希望该方法的行为如下:

C("abc").process()       # prints "abc"
C("abc").process("xyz")  # prints "xyz"

这里有什么问题,为什么这不起作用?我怎么能做这个工作?


沧海一幻觉
浏览 518回答 3
3回答

慕盖茨4494581

您无法将此定义为默认值,因为在定义任何实例之前定义方法时会计算默认值。通常的模式是做这样的事情:class C:     def __init__(self, format):         self.format = format    def process(self, formatting=None):         if formatting is None:             formatting = self.format        print(formatting)self.format如果将只用于formatting为None。要演示默认值的工作方式,请参阅此示例:def mk_default():     print("mk_default has been called!")def myfun(foo=mk_default()):     print("myfun has been called.")print("about to test functions")myfun("testing")myfun("testing again")这里的输出:mk_default has been called!about to test functions myfun has been called.myfun has been called.注意如何mk_default只调用一次,这发生在函数被调用之前!

繁华开满天机

在Python中,名字self是不是特别的。它只是参数名称的约定,这就是为什么有一个self参数__init__。(实际上,__init__也不是很特别,特别是它实际上并没有创建对象......这是一个更长的故事)C("abc").process()创建一个C实例,process在C类中查找方法,并以C实例作为第一个参数调用该方法。因此,self如果您提供参数,它将最终出现在参数中。但是,即使您拥有该参数,也不会允许您编写类似的内容def process(self, formatting = self.formatting),因为self在您设置默认值时尚未在范围内。在Python中,参数的默认值是在编译函数时计算的,并且“卡在”函数中。(这就是为什么,如果您使用默认值[],该列表将记住对函数的调用之间的更改。)我怎么能做这个工作?传统方法是None默认使用,并检查该值并在函数内替换它。您可能会发现为此目的创建一个特殊值(一个object实例就是您所需要的,只要您隐藏它以便调用代码不使用相同的实例)而不是None。无论哪种方式,你应该检查这个值is,而不是==。
随时随地看视频慕课网APP

相关分类

Python
我要回答