我一直在关注Miguel Grinberg的Flask Web开发,并在尝试创建数据库角色时遇到了障碍。这本书建议我使用以下命令来运行 shell,生成一个 python shell 并创建数据库角色:
https://i.stack.imgur.com/BdMx5.png
但是当相同的命令时,它不会给我一个可以编写命令的python shell。它只是启动服务器并运行程序,使我无法执行创建数据库角色所需的命令。
https://i.stack.imgur.com/czTqF.png
在这两种情况下,hello.py 都只是一个简单的烧瓶程序,其中包含相关的数据库类。不知道为什么会这样。我已经激活了虚拟环境并按照文本中所述完成了所有操作。有什么想法吗?
这是 hello.py 中的全部代码
# imports
from flask.ext.sqlalchemy import SQLAlchemy
from flask import Flask, render_template
import os
from flask.ext.wtf import Form
from wtforms import StringField, SubmitField
from wtforms.validators import Required
from flask.ext.bootstrap import Bootstrap
# App and DB config
basedir = os.path.abspath(os.path.dirname(__file__))
app = Flask(__name__)
bootstrap = Bootstrap(app)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///' + os.path.join(basedir, 'data.sqlite')
app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True
db = SQLAlchemy(app)
# classes
class Role(db.Model):
__tablename__ = 'roles'
id = db.Column(db.Integer, primary_key = True)
name = db.Column(db.String(64), unique=True)
users = db.relationship('User', backref='role')
def __repr__(self):
return '<Role %r>' % self.name
class User(db.Model):
__tablename__ = 'users'
id = db.Column(db.Integer, primary_key = True)
name = db.Column(db.String(64), unique=True, index=True)
role_id = db.Column(db.Integer, db.ForeignKey('roles.id'))
def __repr__(self):
return '<User %r>' % self.username
class NameForm(Form):
name = StringField('What is your name?',validators=[Required()])
favorite = StringField('What is your favorite food?',validators=[Required()])
submit = SubmitField('Submit')
if __name__ == '__main__':
app.run(debug=True)
无论您遵循什么说明,都假设您已经设置了 Flask-Script。 你的代码没有,它只是为了直接运行应用而编写的。 安装 Flask-Script 并修改代码以包含以下部分,然后按照所述运行 shell。
pip install flask-script
from flask_script import Manager
manager = Manager(app)
if __name__ == '__main__':
manager.run()
$ python hello.py shell
>>> from hello import db
>>> db.create_all()