3

我正在尝试为我的 Web 应用程序添加路径,但由于某种原因出现最大递归深度错误

def runSQL(sql):
    db = sqlite3.connect('zadanie.db')
    c = db.cursor()
    c.execute(sql)
    data = c.fetchall()
    db.commit()
    c.close()
    return data  

def Subjects(): 
    sql = "SELECT (here is my query)" 
    data = runSQL(sql) 
    return data

@app.route('/subjects')
def Subjects():
    sub = template('look4.html', rows=Subjects())              
    return sub

我试图将递归限制设置为更高的数字,但随后发生错误分段错误 11。
我将不胜感激任何调试建议:)

4

1 回答 1

2

问题不在于递归深度。如您所见,您定义了两个名为Subject.

结果 Python 将用第二个覆盖第一个。现在第二个调用(你认为是)前一个。但是由于Subjects被覆盖,它将再次重定向到该函数,因此:

@app.route('/subjects')
def Subjects():
    sub = template('look4.html', rows=Subjects())
    return sub

会陷入无限递归。解决方案是简单地重命名两者之一(可能最好重命名第一个),然后更改调用,例如:

def subjects_query(): 
    sql = "SELECT (here is my query)" 
    data = runSQL(sql) 
    return data

@app.route('/subjects')
def subjects():
    sub = template('look4.html', rows=subjects_query())              
    return sub

另外约定是 Python 中的函数是带下划线的小写,所以你最好将第二个函数重命名为subjects(就像我在这里所做的那样)。

于 2018-01-20T21:48:15.403 回答