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 相关文章推荐
使用Python编写简单的端口扫描器的实例分享
Dec 18 Python
详解Python函数可变参数定义及其参数传递方式
Aug 02 Python
Django原生sql也能使用Paginator分页的示例代码
Nov 15 Python
Python实现两款计算器功能示例
Dec 19 Python
Python Web程序部署到Ubuntu服务器上的方法
Feb 22 Python
python处理数据,存进hive表的方法
Jul 04 Python
python多线程实现TCP服务端
Sep 03 Python
Django项目基础配置和基本使用过程解析
Nov 25 Python
python利用线程实现多任务
Sep 18 Python
python 基于UDP协议套接字通信的实现
Jan 22 Python
TensorFlow的环境配置与安装方法
Feb 20 Python
python中tkinter复选框使用操作
Nov 11 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实现评委评分器
2015/07/31 PHP
php json转换相关知识(小结)
2018/12/21 PHP
php基于协程实现异步的方法分析
2019/07/17 PHP
js的with语句使用方法
2007/09/21 Javascript
自己动手制作jquery插件之自动添加删除行功能介绍
2011/10/14 Javascript
jQuery判断iframe中元素是否存在的方法
2013/05/11 Javascript
一个不错的js html页面倒计时可精确到秒
2014/10/22 Javascript
node.js操作mongoDB数据库示例分享
2014/11/26 Javascript
深入分析JSONP跨域的原理
2014/12/10 Javascript
jQuery学习笔记之2个小技巧
2015/01/19 Javascript
JS+CSS实现Li列表隔行换色效果的方法
2015/02/16 Javascript
编写高质量JavaScript代码的基本要点
2016/03/02 Javascript
老生常谈js动态添加事件--- 事件委托
2016/07/19 Javascript
js注入 黑客之路必备!
2016/09/14 Javascript
tablesorter.js表格排序使用方法(支持中文排序)
2017/02/10 Javascript
vue中使用ueditor富文本编辑器
2018/02/08 Javascript
微信小程序(订阅消息)功能
2019/10/25 Javascript
微信小程序button标签open-type属性原理解析
2020/01/21 Javascript
jquery实现轮播图特效
2020/04/12 jQuery
JavaScript代码压缩工具UglifyJS和Google Closure Compiler的基本用法
2020/04/13 Javascript
详解JavaScript 作用域
2020/07/14 Javascript
解决pytorch GPU 计算过程中出现内存耗尽的问题
2019/08/19 Python
Python实现大数据收集至excel的思路详解
2020/01/03 Python
浅谈python print(xx, flush = True) 全网最清晰的解释
2020/02/21 Python
Pandas中DataFrame基本函数整理(小结)
2020/07/20 Python
python爬取”顶点小说网“《纯阳剑尊》的示例代码
2020/10/16 Python
运行python提示no module named sklearn的解决方法
2020/11/29 Python
英国最大的老式糖果店:A Quarter Of
2017/04/08 全球购物
The Body Shop美体小铺西班牙官网:天然化妆品
2019/06/21 全球购物
介绍一下SQL Server的全文索引
2013/08/15 面试题
资产评估专业学生的自我鉴定
2013/11/14 职场文书
大学本科毕业生的自我鉴定
2013/11/26 职场文书
蛋糕店的商业计划书范文
2014/01/27 职场文书
二年级语文教学反思
2014/02/02 职场文书
会计学毕业生求职信
2014/06/25 职场文书
反邪教学习心得体会
2016/01/15 职场文书