我正在修改按照 Miguel Grinberg 的 Flask Mega 教程创建的 Flask 应用程序,以便可以发布推文。我已经导入了 tweepy 以访问 twitter api,并修改了数据库以保存推文的预定时间。我希望从 SQLAlchemy 数据库中迭代 current_user 的帖子和相应的时间,并在当前时间与预定时间匹配时发布。
model.py中的数据库模型修改如下:
class Post(db.Model):
id = db.Column(db.Integer, primary_key = True)
body = db.Column(db.String(140))
timestamp = db.Column(db.DateTime, index=True, default=datetime.utcnow)
socialnetwork = db.Column(db.String(40))
user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
#This is the stuff for scheduling, just date
hour = db.Column(db.Integer)
minute = db.Column(db.Integer)
day = db.Column(db.Integer)
month = db.Column(db.Integer)
year = db.Column(db.Integer)
ampm = db.Column(db.String(2))
作为一个测试,我想遍历当前用户的帖子并使用 tweepy 发布推文:
@app.before_first_request
def activate_job():
def run_job():
posts = current_user.followed_posts().filter_by(socialnetwork ='Twitter')
for post in posts:
tweepy_api.update_status(message)
time.sleep(30)
thread = threading.Thread(target=run_job)
thread.start()
但是,这返回了错误:
AttributeError: 'NoneType' object has no attribute 'followed_posts'
在终端上。这让我感到困惑,因为我在同一个文件中多次使用 current_user 来过滤社交网络的帖子。
如routes.py中的以下情况
@app.route('/<username>')
@login_required
def user(username):
user = User.query.filter_by(username = username).first_or_404()
socialnetwork = request.args.get("socialnetwork")
if socialnetwork == 'Facebook':
posts = current_user.followed_posts().filter_by(socialnetwork = 'Facebook')
elif socialnetwork == 'Twitter':
posts = current_user.followed_posts().filter_by(socialnetwork = 'Twitter')
else:
posts = current_user.followed_posts()
return render_template('user.html', user = user, posts = posts, form = socialnetwork)
以上不会产生错误并且可以完美运行。
如果有人能阐明我做错了什么,我将不胜感激。