Python Flask:无法初始化SQLite数据库

时间:2016-12-26 20:24:34

标签: python-2.7 sqlite flask command-line-interface

我按照此处找到的Flask教程:http://flask.pocoo.org/docs/0.12/tutorial/。我已按照步骤0-4进行操作,但无法理解步骤5(创建数据库);我已阅读并将相关函数添加到我的flaskr.py脚本中,因此它目前看起来像这样:

# all the imports
import os
import sqlite3
from flask import Flask, request, session, g, redirect, url_for, abort, render_template, flash

app = Flask(__name__) # create the application instance :)
app.config.from_object(__name__) # load config from this file , flaskr.py

# Load default config and override config from an environment variable
app.config.update(dict(
    DATABASE=os.path.join(app.root_path, 'flaskr.db'),
    SECRET_KEY='development key',
    USERNAME='admin',
    PASSWORD='default'
))
app.config.from_envvar('FLASKR_SETTINGS', silent=True)

def connect_db():
    """Connects to the specific database."""
    rv = sqlite3.connect(app.config['DATABASE'])
    rv.row_factory = sqlite3.Row
    return rv

def get_db():
    """Opens a new database connection if there is none yet for the
    current application context.
    """
    if not hasattr(g, 'sqlite_db'):
        g.sqlite_db = connect_db()
    return g.sqlite_db

@app.teardown_appcontext
def close_db(error):
    """Closes the database again at the end of the request."""
    if hasattr(g, 'sqlite_db'):
        g.sqlite_db.close()

def init_db():
    db = get_db()
    with app.open_resource('schema.sql', mode='r') as f:
        db.cursor().executescript(f.read())
    db.commit()

@app.cli.command('initdb')
def initdb_command():
    """Initializes the database."""
    init_db()
    print('Initialized the database.')

if __name__ == '__main__':
    init_db()
    app.run()

然后教程说可以通过调用

来初始化数据库
flask initdb

运行此命令会产生:

Usage: flask [OPTIONS] COMMAND [ARGS]...

Error: No such command "initdb".

从目前为止的教程开始,我的应用程序目录中没有flask脚本。我还做了一些更多的研究,并找到了这个资源:http://flask.pocoo.org/docs/0.12/cli/,它声明虚拟环境附带了这个烧瓶脚本,但我的虚拟环境没有这个文件。我通过导航到我的根目录并使用:

来验证这一点
find . -name flask
find . -name flask.py

但是,这些命令都不会返回任何匹配项。由于我对Flask相对较新,我可能会遗漏一些简单的东西;谁能解释我所缺少的内容并提供解决方法?提前谢谢!

3 个答案:

答案 0 :(得分:1)

纯粹的教育猜测在这里。但是在您展示的代码中,您有以下内容:

@app.cli.command('initdb')
def initdb_command():
    """Initializes the database."""
    init_db()
    print('Initialized the database.')

我认为那应该是

@app.cli.command()
def initdb():
    ...

请注意,装饰器没有参数,并且该函数已重命名以匹配您在命令行中调用的命令。

粗略地浏览Flask并单击文档并不表示您可以将字符串传递给装饰器并将其调用为标记。

答案 1 :(得分:1)

我收到了与完成本教程相同的错误。我发现我已经打开了一个新的终端窗口来处理服务器在另一个服务器上运行的原因。我通过再次运行export命令解决了这个问题:

export FLASK_APP=flaskr

然后:

flask initdb

答案 2 :(得分:0)

试试这个:

python -m flask initdb

要检查的另一件事是,如果您正在阅读本教程:您的__init__.py文件是否位于正确的位置?它应该位于第二级flaskr目录中,而不是在顶级目录中。