Python Django 后台管理之后台模型属性详解


Posted in Python onApril 25, 2021

十八、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)

注册成功的结果就是在后台页面,可以看到对模型的操作入口。

Python Django 后台管理之后台模型属性详解

其它注册方式
因为上述 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

上述内容补充完整之后,就可以进行后台对数据进行维护了。

Python Django 后台管理之后台模型属性详解

接下来就要学习第一个属性: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 页面查看到最终结果了。

Python Django 后台管理之后台模型属性详解

18.2.2 actions_on_top/actions_on_bottom

控制动作条的显示位置,动作即操作。

Python Django 后台管理之后台模型属性详解

修改 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 之后,后面的数字消失。

Python Django 后台管理之后台模型属性详解

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"]

最终呈现的数据如下:

Python Django 后台管理之后台模型属性详解

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)

重新运行迁移命令,然后运行应用,得到如下效果。

Python Django 后台管理之后台模型属性详解

接下来使用该字段进行数据的展示,在 admin.py 文件中进行设置。

empty_value_display = '/'

运行之后得到的结果如下:

Python Django 后台管理之后台模型属性详解

18.2.6 fields

控制显示的表单字段与顺序组合。例如增加如下代码之后,核对结果如下:

list_display = ["_id", 'warp_name', "mobile", "create_time","mark"]
fields = ["mobile","name"]

Python Django 后台管理之后台模型属性详解

18.2.7 其他要补充的属性

filter_horizontalfilter_vertical
筛选菜单的横排展示与竖排展示。

list_editable
可编辑字段。

list_filter
过滤器属性设置。

list_per_page
每页显示的数据条数。

ordering
排序字段列表。

paginator
分页类对象,需要提前引入 django.core.paginator.Paginator

radio_fields
字段在表单中是单选按钮。

readonly_fields
不可编辑字段。

search_fileds
列表页增加的筛选字段。

到此这篇关于Python Django 后台管理之后台模型属性的文章就介绍到这了,更多相关Python Django 后台管理内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Django如何配置mysql数据库
May 04 Python
解决python3 urllib 链接中有中文的问题
Jul 16 Python
Python多进程fork()函数详解
Feb 22 Python
Python实现线性判别分析(LDA)的MATLAB方式
Dec 09 Python
python3 webp转gif格式的实现示例
Dec 10 Python
Python os模块常用方法和属性总结
Feb 20 Python
浅谈Python中os模块及shutil模块的常规操作
Apr 03 Python
pandas 像SQL一样使用WHERE IN查询条件说明
Jun 05 Python
python开发一款翻译工具
Oct 10 Python
python动态规划算法实例详解
Nov 22 Python
Python 实现PS滤镜中的径向模糊特效
Dec 03 Python
使用Djongo模块在Django中使用MongoDB数据库
Jun 20 Python
如何用python反转图片,视频
python基于tkinter制作m3u8视频下载工具
用python自动生成日历
解决Django transaction进行事务管理踩过的坑
Apr 24 #Python
pdf论文中python画的图Type 3 fonts字体不兼容的解决方案
Apr 24 #Python
Python使用UDP实现720p视频传输的操作
python通配符之glob模块的使用详解
Apr 24 #Python
You might like
php生成zip文件类实例
2015/04/07 PHP
PHP面向对象程序设计组合模式与装饰模式详解
2016/12/02 PHP
彻底搞懂PHP 变量结构体
2017/10/11 PHP
PHP常见加密函数用法示例【crypt与md5】
2019/01/27 PHP
Javascript 对象的解释
2008/11/24 Javascript
JQuery之focus函数使用介绍
2013/08/20 Javascript
js控制frameSet示例
2013/09/10 Javascript
js实现弹窗插件功能实例代码分享
2013/12/12 Javascript
jquery实现两边飘浮可关闭的对联广告
2015/11/27 Javascript
jQuery UI库中dialog对话框功能使用全解析
2016/04/23 Javascript
Angular2开发——组件规划篇
2017/03/28 Javascript
详解vue模拟加载更多功能(数据追加)
2017/06/23 Javascript
基于rem的移动端响应式适配方案(详解)
2017/07/07 Javascript
解决ionic和angular上拉加载的问题
2017/08/03 Javascript
Bootstrap开发中Tab标签页切换图表显示问题的解决方法
2018/07/13 Javascript
vue props 单项数据流实例分享
2020/02/16 Javascript
[02:37]2018DOTA2亚洲邀请赛赛前采访 VP.no[o]ne心中最强SOLO是谁
2018/04/04 DOTA
[01:02:45]完美世界DOTA2联赛 LBZS vs Forest 第三场 11.07
2020/11/09 DOTA
python结合opencv实现人脸检测与跟踪
2015/06/08 Python
Python六大开源框架对比
2015/10/19 Python
Python进阶之尾递归的用法实例
2018/01/31 Python
Python实现基于TCP UDP协议的IPv4 IPv6模式客户端和服务端功能示例
2018/03/22 Python
Pycharm在创建py文件时,自动添加文件头注释的实例
2018/05/07 Python
python2 与 pyhton3的输入语句写法小结
2018/09/10 Python
python实现LBP方法提取图像纹理特征实现分类的步骤
2019/07/11 Python
简单了解django orm中介模型
2019/07/30 Python
Python中socket网络通信是干嘛的
2020/05/27 Python
纯CSS3实现的8种Loading动画效果
2014/07/05 HTML / CSS
Html5 APP中监听返回事件处理的方法示例
2018/03/15 HTML / CSS
TCP/IP中的TCP和IP分别承担什么责任
2012/04/21 面试题
路由表示做什么用的?在linux环境中怎么来配置一条默认路由?
2013/06/07 面试题
2013年学期结束动员演讲稿
2014/01/07 职场文书
大学生个人求职信例文
2014/07/07 职场文书
中国世界遗产导游词
2015/02/13 职场文书
三傻大闹宝莱坞观后感
2015/06/03 职场文书
导游词之江苏同里古镇
2019/11/18 职场文书