2016-11-22 14 views
1

したがって、私はユーザー投稿を参照しようとしていますか?そして私は、ユーザーによって投稿を参照しようとしているこのエラー__init __()は、予期しないキーワード引数 'author'を1対多に持っています

にエラー

Python 2.7.6 (default, Jun 22 2015, 17:58:13) 
[GCC 4.8.2] on linux2 
Type "help", "copyright", "credits" or "license" for more information. 
>>> from app import db, models 
/usr/local/lib/python2.7/dist-packages/Flask-0.11.1-py2.7.egg/flask/exthook.py:71: ExtDeprecationWarning: Importing flask.ext.sqlalchemy is deprecated, use flask_sqlalchemy instead. 
    .format(x=modname), ExtDeprecationWarning 
>>> u = models.User.query.get(2) 
>>> p = models.Post(title='barn owl', body='thompson', author=u) 
Traceback (most recent call last): 
    File "<stdin>", line 1, in <module> 
TypeError: __init__() got an unexpected keyword argument 'author' 

を得続けます。

Models.py

from app import app, db, bcrypt, slugify, flask_whooshalchemy, JWT, jwt_required, current_identity, safe_str_cmp 
from sqlalchemy import Column, Integer, DateTime, func 
from app import (TimedJSONWebSignatureSerializer 
          as Serializer, BadSignature, SignatureExpired) 

import datetime 


class User(db.Model): 
    id = db.Column(db.Integer, primary_key=True) 
    username = db.Column(db.String(80), unique=True) 
    password = db.Column(db.String(20), unique=True) 
    posts = db.relationship('Post', backref='author', lazy='dynamic') 

    def __init__(self, username, password): 
     self.username = username 
     self.password = bcrypt.generate_password_hash(password, 9) 

    def is_authenticated(self): 
     return True 

    def is_active(self): 
     return True 

    def is_anonymous(self): 
     return False 

    def get_id(self): 
     return (self.id) 

    def __repr__(self): 
     return '<User %r>' % self.username 


class Post(db.Model): 
    __tablename__ = "posts" 

    id = db.Column(db.Integer, primary_key=True) 
    title = db.Column(db.String(80)) 
    body = db.Column(db.Text) 
    user_id = db.Column(db.Integer, db.ForeignKey('user.id')) 
    # slug = db.Column(db.String(80), index=True, nullable=True) 

    time_created = Column(DateTime(timezone=True), server_default=func.now()) 
    time_updated = Column(DateTime(timezone=True), onupdate=func.now()) 

    def __init__(self, title, body): 
     self.title = title 
     self.body = body 

     # self.slug = slugify(title).lower() 

私は誰にもナッツ

+0

は、 '作品 –

+1

、それが参照していないユーザーが投稿(著者は= U、ボディ= 'トンプソン'、タイトル= 'メンフクロウ')' P = models.Postで 'author'のパラメータを削除します。私の言っていることが分かるよね ? – BARNOWL

答えて

2

それとも関係として著者を追加著者を__init__メソッド

にパラメータとして追加する
# inside Post definition 
author = db.relationship("User") 

def __init__(self,title,body,author): 
    self.author = author 
+0

にも同じ闘争を持ったこのショットカイル – BARNOWL

+0

それは私にこの sqlalchemy.exc.ArgumentError与えた:「User.posts」の関係に後方参照「作者」を作成中にエラーが発生しました:その名前のプロパティをMapper | Post | postsにあります。 – BARNOWL

+0

Userクラスから投稿行を削除し、User.postsを引き続き使用するには、投稿者の関係にbackref = "posts"を追加してください。 –

2

何をして行くことについての提案、IMを持っていない、私は本当に成功を持っていないflask mega tutorialイムを参照してきた、かなり混乱していますあなたが必要です:

p = models.Post(title='barn owl', body='thompson', user_id=u.id) 
#             ^^^^^^^^^^ 

そして、カイルが述べたように、user_id引数をPost__init__

def __init__(self, title, body, user_id): 
    ... 
    self.body = body 
    self.user_id = user_id 
    ... 

あなたの投稿がuser_idが含まれているため、ないauthor

class Post(db.Model): 
    ... 
    user_id = db.Column(db.Integer, db.ForeignKey('user.id')) 
    ... 

とあなたのユーザーがidがあります

class User(db.Model): 
    id = db.Column(db.Integer, primary_key=True) 
    ... 
+0

動作しませんでした。__init __()が予期せぬキーワードの引数を持っています – BARNOWL

+0

今は完全にエラーが発生していますか? – Bahrom

+1

彼は '__init__'を定義していて、authorという名前のパラメータを期待するように言っていないので、それは非常に明白です –

関連する問題