按降序排列Jinja列表

3
我正在使用Jinja模板引擎在Flask中创建一个网站。我有一个公告列表,但没有好的方法来对它们进行排序。
现在它们是通过id在表格中调用的。我想按最新的顺序排序(这意味着最高的id)。
像这样:
  • P1
    • 5
    • 4
    • 3
  • P2
    • 2
    • 1
在我的HTML中,我已经为Jinja放置了这个指令:
<div id="main"> 

{% autoescape false %}
{% for announcement in announcements.items|sort(attribute='id', reverse = True) %}

  <a name={{announcement.title}}></a>
  <h1>{{announcement.title}} - Posted on: {{announcement.date}}</h1>
  {{announcement.body}}
  <br/>
  <hr/>

{% endfor %}
{% endautoescape %}

 <p class = "footer">{% if announcements.has_prev %}<a href="{{ url_for('index', page = announcements.prev_num) }}"><< Newer posts</a>{% else %}<< Newer posts{% endif %} | 
 {% if announcements.has_next %}<a href="{{ url_for('index', page = announcements.next_num) }}">Older posts >></a>{% else %}Older posts >>{% endif %} </p>

<br/>
</div>

还有Python:

from flask import render_template, Markup
from app import app
from config import POSTS_PER_PAGE
from models import Announcement, VideoAnnouncement

@app.route('/')
@app.route('/index')
@app.route('/index/<int:page>')
def index(page = 1):
    loggedOut = True
    announcements = Announcement.query.paginate(page, POSTS_PER_PAGE, True)
    videoAnnounce = VideoAnnouncement.query.all()
    return render_template("index.html", announcements = announcements, videoAnnouncements = videoAnnounce , loggedOut = loggedOut)

但是它的排序方式如下:

  • P1
    • 3
    • 2
    • 1
  • P2
    • 5
    • 4

有没有任何一种按降序排列的方法不会被页面搞乱?

(我希望我的问题表述清楚了)


2
你的问题在于你是在分页之后再对结果进行排序。你需要找到一种在分页之前对它们进行排序的方法。难道你不能在查询中添加一个排序吗? - John La Rooy
@gnibbler 嘿!太棒了,这个成功地运行了! - Thegluestickman
1个回答

2
采纳gnibbler的建议,我在分页之前重新排列了查询语句。
更新后的代码:
from flask import render_template, Markup
from app import app
from config import POSTS_PER_PAGE
from models import Announcement, VideoAnnouncement

@app.route('/')
@app.route('/index')
@app.route('/index/<int:page>')
def index(page = 1):
    loggedOut = True
    query = Announcement.query.order_by(Announcement.id.desc())
    announcements = query.paginate(page, POSTS_PER_PAGE, True)
    videoAnnounce = VideoAnnouncement.query.all()
    return render_template("index.html", announcements = announcements, videoAnnouncements = videoAnnounce , loggedOut = loggedOut)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接