我正在尝试用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。
考虑您在全局范围内定义了函数:
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 中方法的工作原理!