Python Django 後臺管理之後臺模型屬性詳解
十八、Django 後臺模型屬性篇
繼續在之前的項目中進行代碼的編碼,首先要回憶一下通過 createsuperuser
命令創建的管理員賬號,如果忘記瞭,需要重新創建一個。
本篇博客涉及的代碼都在 admin.py
文件中,如果你首次打開本篇文章,請翻看本文結尾出的目錄大綱,可以再次學習。
為瞭便於學習,提前在 models.py
中新增一個類,代碼如下:
from django.db import models class MyCenter(models.Model): pass
18.1 在 admin 中註冊模型
為瞭讓 Django 能對 models.py
文件中的類進行管理操作,需要先註冊模型。
把上文提及的 MyCenter
模型進行註冊,此時 admin.py
文件的代碼如下:
from django.contrib import admin from .models import MyCenter class MyCenterAdmin(admin.ModelAdmin): pass admin.site.register(MyCenter, MyCenterAdmin)
註冊成功的結果就是在後臺頁面,可以看到對模型的操作入口。
其它註冊方式
因為上述 MyCenterAdmin
沒有實現任何功能,所以可以省略掉。修改代碼如下:
from django.contrib import admin from .models import MyCenter admin.site.register(MyCenter)
同樣可以使用裝飾器達到相同的效果。
from django.contrib import admin from .models import MyCenter @admin.register(MyCenter) class MyCenterAdmin(admin.ModelAdmin): pass
18.2 Model.Admin 類提供的屬性
在上文你已經看到瞭,admin.py
文件中的類默認繼承自 Model.Admin
,既然繼承自它,那接下來要掌握的就是它給我們提供的屬性內容瞭。
工作開始前,我們先將 admin.py
文件中的代碼進行修改,主要為瞭便於頁面展示。
models.py
from django.db import models from django.contrib.auth.models import User class Customer(models.Model): # 自增主鍵 _id = models.AutoField(primary_key=True) name = models.CharField(max_length=20, verbose_name="客戶名") mobile = models.IntegerField(default=0, verbose_name="手機號碼") class Score(models.Model): # 自增主鍵 _id = models.AutoField(primary_key=True) customer = models.ForeignKey(Customer, on_delete=models.CASCADE) score = models.IntegerField(default=0, verbose_name="分數")
admin.py
from django.contrib import admin from .models import Customer @admin.register(Customer) class CustomerAdmin(admin.ModelAdmin): pass
上述內容補充完整之後,就可以進行後臺對數據進行維護瞭。
接下來就要學習第一個屬性:date_hierarchy
。
18.2.1 date_hierarchy
該屬性用於將時間列轉換為可過濾字段,完成該操作需要在 models.py
中新增好 models.DateField
類型的字段。
create_time = models.DateField(default=timezone.now)
當模型發生變化,需要用下述命令進行一下同步。
python manage.py makemigrations scoring python manage.py migrate
模型變化遷移之後,就可以在 admin.py
中進行配置瞭。
from django.contrib import admin from .models import Customer @admin.register(Customer) class CustomerAdmin(admin.ModelAdmin): date_hierarchy = "create_time"
此時再運行應用之後,就可以在 customer 頁面查看到最終結果瞭。
18.2.2 actions_on_top/actions_on_bottom
控制動作條的顯示位置,動作即操作。
修改 admin.py
文件代碼如下,可以控制動作條的展示位置。
@admin.register(Customer) class CustomerAdmin(admin.ModelAdmin): date_hierarchy = "create_time" # actions_on_top = False actions_on_bottom = True
18.2.3 actions_selection_counter
動作條後面的計數是否展示。當其設置為 False 之後,後面的數字消失。
18.2.4 list_display
該屬性可以控制模型中列表顯示的字段。代碼修改為如下內容:
@admin.register(Customer) class CustomerAdmin(admin.ModelAdmin): date_hierarchy = "create_time" actions_on_top = False actions_on_bottom = True list_display = ["_id", "name", "mobile", "create_time"]
最終呈現的數據如下:
list_display
還可以給字段嵌套一個函數。
def warp_name(obj): return f"客戶名:{obj.name}" @admin.register(Customer) class CustomerAdmin(admin.ModelAdmin): date_hierarchy = "create_time" actions_on_top = False actions_on_bottom = True # warp_name 為函數名,函數內會接收一個對象 list_display = ["_id", warp_name, "mobile", "create_time"] warp_name.short_description = "格式化的名字"
也可以將上述代碼的 warp_name
函數,放置到 CustomerAdmin
內部。
@admin.register(Customer) class CustomerAdmin(admin.ModelAdmin): date_hierarchy = "create_time" actions_on_top = False actions_on_bottom = True def warp_name(self, obj): return f"客戶名:{obj.name}" list_display = ["_id", 'warp_name', "mobile", "create_time"] warp_name.short_description = "格式化名字"
此時最大的區別就是 list_display
的列表中自定義的函數為一個字符串形式。
默認情況下 list_display
的第一項是超鏈接,點擊可以進行編輯頁面,可以通過 list_display_links 進行設置。
list_display_links
:為 None 表示不顯示任何鏈接;列表
:標記哪些需要超鏈接。
18.2.5 empty_value_display
空數據展示的方式,默認空數據展示的是 --
,使用該屬性之後,可以進行自定義設置。
修改 models.py
文件,增加備註列。
class Customer(models.Model): # 自增主鍵 _id = models.AutoField(primary_key=True) name = models.CharField(max_length=20, verbose_name="客戶名") mobile = models.IntegerField(default=0, verbose_name="手機號碼") create_time = models.DateField(default=timezone.now) mark = models.CharField(max_length=50, null=True, blank=True)
重新運行遷移命令,然後運行應用,得到如下效果。
接下來使用該字段進行數據的展示,在 admin.py
文件中進行設置。
empty_value_display = '/'
運行之後得到的結果如下:
18.2.6 fields
控制顯示的表單字段與順序組合。例如增加如下代碼之後,核對結果如下:
list_display = ["_id", 'warp_name', "mobile", "create_time","mark"] fields = ["mobile","name"]
18.2.7 其他要補充的屬性
filter_horizontal 與 filter_vertical
篩選菜單的橫排展示與豎排展示。
list_editable
可編輯字段。
list_filter
過濾器屬性設置。
list_per_page
每頁顯示的數據條數。
ordering
排序字段列表。
paginator
分頁類對象,需要提前引入 django.core.paginator.Paginator
。
radio_fields
字段在表單中是單選按鈕。
readonly_fields
不可編輯字段。
search_fileds
列表頁增加的篩選字段。
到此這篇關於Python Django 後臺管理之後臺模型屬性的文章就介紹到這瞭,更多相關Python Django 後臺管理內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Django Admin 管理工具的實現
- Django一小時寫出賬號密碼管理系統
- Django記錄操作日志與LogEntry的使用詳解
- python Django框架快速入門教程(後臺管理)
- 淺談Python之Django(四)