2015-07-12 133 views
0

我是创建Web应用程序的新手,我决定从学习Flask开始。我将社交网络作为练习和学习一些基本技能的辅助项目。从流中删除帖子

到目前为止,我已经能够构建一个用户可以发布的“Stream”,类似于Twitter。 我一直在努力寻找一种方法来允许用户删除帖子。我正在使用Peewee库的SQLite数据库。这是我曾尝试:

@app.route('/delete_post/<int:post_id>') 
@login_required 
def delete_post(post_id): 
    delete = models.Post.select().where(models.Post.id == post_id) 
    try: 
     models.DATABASE.delete(delete) 
    except models.DoesNotExist: 
     abort(404) 
    else: 
     flash("This post has successfully been deleted.", "success") 
    return redirect(url_for('stream', stream = stream)) 

而且,这里是一个邮政是如何创建的:

class Post(Model): 
    timestamp = DateTimeField(default=datetime.datetime.now()) 
    user = ForeignKeyField(
     rel_model= User, 
     related_name='posts' 
    ) 
    content = TextField() 
    class Meta: 
     database = DATABASE 
     order_by = ('-timestamp',) 

最后,存在这样的情况,当使用选择delete_post方法将被称为模板“删除“

{% extends "base.html" %} 

{% block content %} 
{% for post in stream %} 
    <article> 
     <h2> 
      <a href="{{ url_for('stream', username=post.user.username) }}">{{ post.user.username }}</a> 
     </h2> 
     <i class="clock"></i> 
     <time> 
     {{ post.timestamp.strftime("%a, %d %b %Y %H:%M") }} 
     </time> 
     <a href="{{ url_for('view_post', post_id=post.id) }}" class="view">View</a> 
     <a href="{{ url_for('delete_post', post_id=post.id) }}" class="view" >| Delete</a> 

     <div class="post"> 
      {{ post.content }} 
     </div> 
    </article> 
{% endfor %} 
{% endblock %} 

如何删除帖子?当我尝试我的解决方案时,我得到:AttributeError: 'SqliteDatabase' object has no attribute 'delete' 我知道这个问题很啰嗦,但任何帮助将非常感激,并将在未来的项目中帮助我很多。让我知道是否需要澄清其他事情。

谢谢!

+1

那么真正的问题是什么? – Boris

+0

我想知道如何去删除帖子 –

+0

所以,再次,真正的问题是什么?好像你知道如何删除一篇文章,你只是写了一篇文章。 – davidism

回答

1

删除:

def delete_post(post_id): 
    try: 
     post = models.Post.select().where(models.Post.id == post_id).get() 
    except models.Post.DoesNotExist: 
     abort(404) 

    post.delete_instance() 
    flash("This post has successfully been deleted.", "success") 
    return redirect(url_for('stream', stream = stream)) 

或者,你可以写:

def delete_post(post_id): 
    post = models.Post.delete().where(models.Post.id == post_id).execute() 
    flash("This post has successfully been deleted.", "success") 
    return redirect(url_for('stream', stream = stream)) 

编辑:我也只是想你指向文档,涵盖了各种主题。 .. http://docs.peewee-orm.com/en/latest/peewee/querying.html#deleting-records