Python3 NameError:未为已定义的 @staticmethod 定义名称“方法”

问题描述 投票:0回答:1

我正在尝试用python3编写一个简单的递归函数。当我学习OO Java时,我也想编写涉及对象的Python代码。下面是我的代码。我提示用户输入一个数字,屏幕应显示 5 之前的每个较小的整数。

class Recursion:
    @staticmethod
    def recursive(x):
        if (x>5):
            print (x)
            recursive(x - 1)

def main(self):
    x = int(input('Enter a number for recursive addition: '))
    recursive(x)

但是,当我在终端上运行它时,它显示:“NameError:名称'recursive'未定义”。错误如下所示:

Python 3.5.1 (v3.5.1:37a07cee5969, Dec  5 2015, 21:12:44) 
[GCC 4.2.1 (Apple Inc. build 5666) (dot 3)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> from Recursion import *
>>> a = Recursion()
>>> a.main()
Enter a number for recursive addition: 10
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/Users/ZycinG/Desktop/Python Practice/Recursion.py", line 9, in main
    recursive(x)
NameError: name 'recursive' is not defined

这里出现问题的原因是什么?我知道如何编写递归函数,给它一个参数,然后让它在终端上运行。但我想练习OOP。

python python-3.x oop recursion nameerror
1个回答
11
投票

考虑您在全局范围内定义了函数:

def recursive(x):
    if (x>5):
        print (x)
        recursive(x - 1)

如果您将其设置为类中的

recusive(10)
,您只需从程序中的其他位置使用
staticmethod
来调用它,并且在函数内类似地调用它:

class Recursion:
    @staticmethod
    def recursive(x):
        if (x>5):
            print (x)
            recursive(x - 1) #this isn't how you call it any more

现在它作为

Recursion.recursive
存储在全局范围中,因此这也是您在函数中引用它的方式:

class Recursion:
    @staticmethod
    def recursive(x):
        if (x>5):
            print (x)
            Recursion.recursive(x - 1)

但是,如果您希望方法能够直接访问类作用域(在函数本地),您可以将其标记为

classmethod
:

class Recursion:
    @classmethod
    def recursive(cls,x): #the first argument is the class
        if (x>5):
            print (x)
            cls.recursive(x - 1)

这有几个好处,首先它可以被称为

Recursion.recursive(10)
x = Recursion() ; x.recursive()
,而且如果合适的话它会使用子类而不是总是使用
Recursion
:

class Recursion:
    def __init__(self,x=None):
        raise NotImplementedError("not intended to initialize the super class")
    @classmethod
    def recursive(x):
        if (x>5):
            print (x)
            return cls.recursive(x - 1)
        else:
            return cls(x)

class R_sub(Recursion):
    def __init__(self,x):
        self._val = x
#now using R_sub.recursive(10) will work fine

尽管即使你不使用

staticmethod
classmethod
你仍然需要引用该方法,作为一个方法:(在 java 中你可以仅通过名称使用这些方法,但 python 基本上强制你使用方法作为
self.METHOD 
类似于java的
this.METHOD

class Recursion:
    def recursive(self,x):
        if (x>5):
            print (x)
            self.recursive(x - 1)

希望这能澄清 Python 中方法的工作原理!

© www.soinside.com 2019 - 2024. All rights reserved.