2016-11-22 92 views
1

所以,即时通讯尝试引用用户的职位?我不断收到此错误__init __()得到一个意想不到的关键字参数'作者'一对多

错误

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() 

我很困惑,我一直在引用flask mega tutorial我不是真的有成功的,没有任何人有任何建议,我将要发疯

+0

删除''中P = models.Post author'参数(标题=“谷仓猫头鹰,身体= '汤普森',作者= U)' –

+1

这样的作品,但它不引用网友的帖子,你知道我的意思 ? – BARNOWL

回答

2

或者只是添加笔者作为一名关系并将作者作为参数添加到方法

# inside Post definition 
author = db.relationship("User") 

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

让我给这个镜头凯尔 – BARNOWL

+0

它给了我这个 sqlalchemy.exc.ArgumentError:创建关系'User.posts'的backref'作者'时出错:该名称的属性存在于映射器'Mapper | Post | posts' – BARNOWL

+0

从User类删除帖子行,并继续使用User.posts,只需在作者关系中添加backref =“posts” –

2

什么你需要的是:

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

而且,正如凯尔提到的,将user_id参数添加到__init__Post的:

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的参数,它非常清楚 –

相关问题