歡迎您光臨本站 註冊首頁

django admin管理工具自定義時間區間篩選器DateRangeFilter介紹

←手機掃碼閱讀     sl_ivan @ 2020-06-10 , reply:0

django admin管理工具有很多好用的功能,例如搜索框、篩選器等,編碼簡單,功能強大。

但是常規的時間篩選有一定侷限性,只能顯示一定時間節點到當前時間這一段時間段內的篩選結果,做不到自由定義時間段篩選,本人找到了可以實現這一功能的插件,就是今天要介紹的DateRangeFilter。

注意: DateRangeFilter只適用於Django 1.4以上的版本。

插件安裝

使用 pip或easy_install:

pip install django-daterange-filter

修改配置

在settings.py中的INSTALLED_APPS如下加入配置項:

  INSTALLED_APPS = (    ...    'daterange_filter'  )

 

加入篩選器

假設你需要普通篩選和通過時間區間進行篩序的字段在models.py裡分別是這麼寫的:

  class TaskModel(models.Model):    ...    user_name = models.CharField(u'用戶名', max_length=128)    submit_time = models.DateTimeField(u'提交時間', auto_now_add=True)    ...

 

那麼,在admin.py引入篩選器插件:

from daterange_filter.filter import DateRangeFilter

以上這點是文檔中最容易被忽視的部分,所以這裡單獨列出來以引起重視。

admin.py中涉及到的DateRangeFilter篩選器完整的部分應該這麼寫:

  from daterange_filter.filter import DateRangeFilter  from django.contrib import admin  from models import TaskModel    class TaskAdmin(admin.ModelAdmin):    list_filter = (      'user_name',      ('submit_time', DateRangeFilter), # this is a tuple      ...    )

 

在admin頁面上註冊後就可以看到效果了。

參考鏈接:https://pypi.org/project/django-daterange-filter/1.1.1/

補充知識:python django orm 過濾 時間,數字比較方法

首先我們來現說一下富比較方法在實際工作中的運用場景,小編一般運用比較多的是時間的比較,數字比較,只要能比較的地方都可以用 如果說 我要創建一條信息,但是如果時間重疊 或者衝突就不能創建成功,

  filter(        (Q(start_time1__lt=start_time2) & Q(end_time1__gt=end_time2)) |        Q(start_time1__range=(start_time, end_time)) |        Q(end_time1__range=(start_time, end_time)))

 


來說上面的代碼,__lt 是小於的意思 start_time1 小於 start_time2 & 並且 end_time1 大於 end_time2 __gt 是大於

‘|'是或者的意思 __range 給出一個時間範圍 在一個範圍之內 在start_time,到end_time 這個範圍之間



[sl_ivan ] django admin管理工具自定義時間區間篩選器DateRangeFilter介紹已經有273次圍觀

http://coctec.com/docs/python/shhow-post-237787.html