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

Dro*_*leT 5 python oop recursion nameerror python-3.x

我正在尝试在 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)
Run Code Online (Sandbox Code Playgroud)

但是,当我在终端上运行它时,它会显示:“NameError: name 'recursive' is not defined”。这是错误的样子:

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
Run Code Online (Sandbox Code Playgroud)

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

Tad*_*sen 9

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

def recursive(x):
    if (x>5):
        print (x)
        recursive(x - 1)
Run Code Online (Sandbox Code Playgroud)

你可以简单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
Run Code Online (Sandbox Code Playgroud)

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

class Recursion:
    @staticmethod
    def recursive(x):
        if (x>5):
            print (x)
            Recursion.recursive(x - 1)
Run Code Online (Sandbox Code Playgroud)

但是,如果您希望方法可以直接访问类范围(在函数本地),您可以将其标记为classmethod

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

这有几个好处,首先它可以被称为Recursion.recursive(10)or ,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)
            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
Run Code Online (Sandbox Code Playgroud)

尽管即使您不使用staticmethodclassmethod仍然需要引用该方法,作为一个方法:(在java中,您可以仅按名称使用这些方法,但python基本上强制您使用self.METHOD类似于java的方法this.METHOD

class Recursion:
    def recursive(self,x):
        if (x>5):
            print (x)
            self.recursive(x - 1)
Run Code Online (Sandbox Code Playgroud)

希望这可以澄清方法在 python 中的工作原理!