2

Python3.4、Flask、および MongoEngine を使用して単純な webapp を作成しようとしています。

WTForms を使用してフォームを作成しようとすると問題が発生します。

データベースと呼ばれる初期化された MongoEngine アプリケーションがあります。

database = MongoEngine(app)

Post というモデル クラスを作成しました。

class Post(database.Document):
    author = database.StringField(
        default='David Y. Stephenson', max_length=255, required=True
    )
    body = database.StringField(required=True)
    comments = database.ListField(
        database.EmbeddedDocumentField('Comment')
    )
    slug = database.StringField(max_length=255, required=True, unique=True)
    tease = database.StringField(max_length=255, required=True)
    time = database.DateTimeField(
        default=datetime.datetime.now, required=True
    )
    title = database.StringField(max_length=255, required=True, unique=True)

このクラスを使用してフォームを作成するルートがあります。

@app.route('/blog/new')
def new():
    form = model_form(Post)
    return render_template('new_blog.html', form=form)

このルートを実行すると、TypeError が発生します。

TypeError: model must be a mongoengine Document schema

WTForm コードを見ると、Post クラスが MongoEngine のBaseDocumentorのインスタンスである必要があるようですDocumentMetaclass classes/usr/local/lib/python3.4/dist-packages/flask_mongoengine/wtf/orm.py読み取りの 223 ~ 224 行目:

from mongoengine.base import BaseDocument, DocumentMetaclass
if not isinstance(model, (BaseDocument, DocumentMetaclass)):
    raise TypeError('model must be a mongoengine Document schema'

Post クラスを手動で確認しようとすると、 のように見えますが、DocumentMetaclassではありませんBaseDocument。追加する

app.logger.debug(isinstance(Post, mongoengine.base.BaseDocument))
app.logger.debug(isinstance(Post, mongoengine.base.DocumentMetaclass))

私のコードに戻ります:

--------------------------------------------------------------------------------
DEBUG in __init__ [__init__.py:57]:
False
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
DEBUG in __init__ [__init__.py:58]:
True
--------------------------------------------------------------------------------

私は何を間違っていますか?

__init__.py私のファイルの全文は次のとおりです。

import datetime
from flask import Flask
from flask import render_template
from flask.ext.mongoengine import MongoEngine
from flask.ext.mongoengine.wtf import model_form
import mongoengine.base


app = Flask(__name__)


app.config['MONGODB_SETTINGS'] = {
    'db': 'davidystephenson',
    'host': 'ds059908.mongolab.com',
    'username': 'david',
    'password': 'opensecret',
    'port': 59908,
}
database = MongoEngine(app)


class Post(database.Document):
    author = database.StringField(
        default='David Y. Stephenson', max_length=255, required=True
    )
    body = database.StringField(required=True)
    comments = database.ListField(
        database.EmbeddedDocumentField('Comment')
    )
    slug = database.StringField(max_length=255, required=True, unique=True)
    tease = database.StringField(max_length=255, required=True)
    time = database.DateTimeField(
        default=datetime.datetime.now, required=True
    )
    title = database.StringField(max_length=255, required=True, unique=True)


@app.route('/')
def index():
    return render_template('index.html')


@app.route('/blog/')
def blog():
    posts = Post.objects.all()
    return render_template('blog.html', posts=posts)


@app.route('/blog/<slug>')
def post(slug):
    post = Post.objects.get(slug=slug)
    return render_template('post.html', post=post)


@app.route('/blog/new')
def new():
    app.logger.debug(isinstance(Post, mongoengine.base.BaseDocument))
    app.logger.debug(isinstance(Post, mongoengine.base.DocumentMetaclass))
    form = model_form(Post)
    return render_template('new_blog.html', form=form)

if __name__ == '__main__':
    app.run(debug=True)
4

2 に答える 2

1

私は同じ問題を見つけます。

例外の前にすべてのローカル変数を出力すると、現在のモデルが条件を満たしていることがわかりました

if not isinstance(model, (BaseDocument, DocumentMetaclass)):

しかし、次はそうではありません。次のモデルは、関連モデルへのパスでした。あなたの例では、database.EmbeddedDocumentField('Comment') です

リストされたモデルへの文字列パスで定義されたリスト プロパティ ListField で発生する例外

comments = database.ListField(
    database.EmbeddedDocumentField('Comment')
)

代わりにモデルクラスで定義

comments = database.ListField(
    database.EmbeddedDocumentField(Comment)
)

Flask-Admin プロジェクトのプルリクエストでこのバグを解決しました。 https://github.com/mrjoes/flask-admin/pull/645

于 2014-09-03T10:03:54.783 に答える