python的時間比較

有個需求是15天內的文章要添加一個 new 的圖標提示html

1. 從數據庫獲取前面8條數據
articlelist1 = Article.objects.filter(column = Column.objects.get(name="公告欄")).order_by("-stick").order_by("-id").all()[:8]mysql

2. 須要使用自定義過濾器來現實時間對比,由於mysql保存時間類型是有時區的,因此不能直接比較,把字符串轉成時間類型再進行對比,要注意對比的時候,年月日就要和年月日對比,年月日時分秒就要和年月日時分秒對比
@register.filter
def isNew(dateValue):
    newSpan = ''     
    date1 = (datetime.strptime(dateValue, "%Y.%m.%d").date() + timedelta(days = 15))
    nowDate = datetime.now().date()
    if date1 >= nowDate:
        newSpan = '<img class="new-a" src="static/images/home/new_a.gif" />'  
    return newSpansql

3. 前臺模版輸出過濾器,要注意html要進行安全過濾,要否則就是一個html字符串,沒法渲染
{% for foo in articlelist1 %}
                                                <li class="cf">
                                                    <a href="/news/{{ foo.pk }}/" title="{{ foo.title }}">{{ foo.title }}</a>{{ foo.pub_date|date:'Y.m.d'|isNew|safe }}<span>{{ foo.pub_date| date:'Y.m.d' }}</span>
                                                </li>
                                                {% endfor %}數據庫

相關文章
相關標籤/搜索