admin 组件的使用
Django 提供了基于 web 的管理工具。Django 自动管理工具是 django.contrib 的一部分。
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'app1.apps.App1Config', ]
admin其实就是一个Django封装好的app而已。
admin 组件如何使用:
例:
创建一个adminDemo django 项目时:
1.urls.py 文件会自动创建好:
from django.contrib import admin from django.urls import path urlpatterns = [ path('admin/', admin.site.urls), ]
2.settings.py文件中:
INSTALLED_APPS=[
'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'app1.apps.App1Config', #一般创建项目时,会自动创建这句话,但如果是用命令 python manage.py startapp app1 时,不会自动创建这句配置,需要自己手动添加
#‘app2.apps.App2config’, #或下面那种,直接配置app2
'app2'
]
3.构建自己的模型类
models.py文件中:
from django.db import models # Create your models here. class Book(models.Model): title = models.CharField(max_length=32) pub_date = models.DateField() price = models.DecimalField(max_digits=5,decimal_places=2) #publish表和BOOK表为一对多的表,外键关联 publish = models.ForeignKey(to="Publish",on_delete=models.CASCADE) #BOOK 表和 Author 表为多对多表,此处会创建第3张表 authors = models.ManyToManyField(to="Author",db_table="book2authors") def __str__(self): return self.title class Publish(models.Model): name = models.CharField(max_length=32) city = models.CharField(max_length=32) email = models.CharField(max_length=32) def __str__(self): return self.name class Author(models.Model): name = models.CharField(max_length=32) age = models.IntegerField() #作者表和作者详情表示一对一的关系 ad = models.OneToOneField(to="AuthorDetail",null=True,on_delete=models.CASCADE) def __str__(self): return self.name class AuthorDetail(models.Model): birthday = models.DateField() telephone = models.BigIntegerField() addr = models.CharField(max_length=64) def __str__(self): return str(self.telephone)
4.在app1(或app2) admin.py文件中:
from django.contrib import admin # Register your models here. from .models import Publish,Author,AuthorDetail,Book from django.utils.safestring import mark_safe class Bookconfig(admin.ModelAdmin): #自定义列 def show_authors(self,obj): print(obj.authors.all()) return ",".join([obj.name for obj in obj.authors.all() ])#作者那列通过循环显示,用逗号分开
#要显示的列 list_display = ["title","price","show_authors",'pub_date',"publish"] search_fields = ["title","price"] #按字段搜索 # list_editable = ["price"] #设置某个字段可编辑 list_filter = ["publish"]#通过出版社查或分类,一般一对多和多对多用该方法 ordering = ["-price"] #按价格从大到小排列 # change_list_template = "mylist.html" #多选批量初始化 def patch_init(self,request,queryset): queryset.update(price=100) patch_init.short_description = "批量初始化" # actions = ["patch_init"] actions = [patch_init] class PublishConfig(admin.ModelAdmin): list_display = ["name","city",'email'] list_display_links = ["city","email"] #默认第一个字段为超链接, 此处自定义超链接字段
#在admin.py中只需要讲Mode中的某个类注册,即可在Admin中实现增删改查的功能 #注册admin.site admin.site.register(Book,Bookconfig) admin.site.register(Author) admin.site.register(AuthorDetail) admin.site.register(Publish,PublishConfig)
5.创建超级管理用户:
通过命令 python manage.py createsuperuser 来创建超级用户,设置用户名,密码和邮箱,访问 http://127.0.0.1:8000/admin/,输入这个账号和密码,就可以进入
admin 给模型类创建好的页面。

输入刚创建好的超级用户名和密码后:

admin的定制
在admin.py中只需要讲Mode中的某个类注册,即可在Admin中实现增删改查的功能,如:
admin.site.register(models.UserInfo)
想要进行更多的定制操作,需要利用ModelAdmin进行操作:
方式一: class UserAdmin(admin.ModelAdmin): list_display = ('user', 'pwd',) admin.site.register(models.UserInfo, UserAdmin) # 第一个参数可以是列表 方式二: @admin.register(models.UserInfo) # 第一个参数可以是列表 class UserAdmin(admin.ModelAdmin): list_display = ('user', 'pwd',)
1. list_display,列表时,定制显示的列。
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
list_display = ('user', 'pwd', 'xxxxx')
def xxxxx(self, obj):
return "xxxxx"
2. list_display_links,列表时,定制列可以点击跳转。
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
list_display = ('user', 'pwd', 'xxxxx')
list_display_links = ('pwd',)
3. list_filter,列表时,定制右侧快速筛选。
4. list_select_related,列表时,连表查询是否自动select_related
5. list_editable,列表时,可以编辑的列
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
list_display = ('user', 'pwd','ug',)
list_editable = ('ug',)
6. search_fields,列表时,模糊搜索的功能
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
search_fields = ('user', 'pwd')
7. date_hierarchy,列表时,对Date和DateTime类型进行搜索
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
date_hierarchy = 'ctime'
8 inlines,详细页面,如果有其他表和当前表做FK,那么详细页面可以进行动态增加和删除
class UserInfoInline(admin.StackedInline): # TabularInline
extra = 0
model = models.UserInfo
class GroupAdminMode(admin.ModelAdmin):
list_display = ('id', 'title',)
inlines = [UserInfoInline, ]
9 action,列表时,定制action中的操作
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
# 定制Action行为具体方法
def func(self, request, queryset):
print(self, request, queryset)
print(request.POST.getlist('_selected_action'))
func.short_description = "中文显示自定义Actions"
actions = [func, ]
# Action选项都是在页面上方显示
actions_on_top = True
# Action选项都是在页面下方显示
actions_on_bottom = False
# 是否显示选择个数
actions_selection_counter = True
10 定制HTML模板
add_form_template = None change_form_template = None change_list_template = None delete_confirmation_template = None delete_selected_confirmation_template = None object_history_template = None
11 raw_id_fields,详细页面,针对FK和M2M字段变成以Input框形式
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
raw_id_fields = ('FK字段', 'M2M字段',)
12 fields,详细页面时,显示字段的字段
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
fields = ('user',)
13 exclude,详细页面时,排除的字段
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
exclude = ('user',)
14 readonly_fields,详细页面时,只读字段
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
readonly_fields = ('user',)
15 fieldsets,详细页面时,使用fieldsets标签对数据进行分割显示
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
fieldsets = (
('基本数据', {
'fields': ('user', 'pwd', 'ctime',)
}),
('其他', {
'classes': ('collapse', 'wide', 'extrapretty'), # 'collapse','wide', 'extrapretty'
'fields': ('user', 'pwd'),
}),
)
16 详细页面时,M2M显示时,数据移动选择(方向:上下和左右)
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
filter_vertical = ("m2m字段",) # 或filter_horizontal = ("m2m字段",)
17 ordering,列表时,数据排序规则
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
ordering = ('-id',)
或
def get_ordering(self, request):
return ['-id', ]
18. radio_fields,详细页面时,使用radio显示选项(FK默认使用select)
radio_fields = {"ug": admin.VERTICAL} # 或admin.HORIZONTAL
19 form = ModelForm,用于定制用户请求时候表单验证
from app01 import models
from django.forms import ModelForm
from django.forms import fields
class MyForm(ModelForm):
others = fields.CharField()
class Meta:
model = models = models.UserInfo
fields = "__all__"
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
form = MyForm
20 empty_value_display = "列数据为空时,显示默认值"
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
empty_value_display = "列数据为空时,默认显示"
list_display = ('user','pwd','up')
def up(self,obj):
return obj.user
up.empty_value_display = "指定列数据为空时,默认显示"
例子2:admin.py中:
from django.contrib import admin # Register your models here. #导入当前文件夹中,某文件中的类 from .models import Book,Publish,AuthorDetail,Author from django.utils.safestring import mark_safe #admin 的定制 , class Bookconfig(admin.ModelAdmin): def show_authors(self,obj): return [obj.name for obj in obj.authors.all()] list_display_links = ["price",] def delbtn(self): return "删除" def a_link(self): return "<a>删除</a>" def b_link(self): return mark_safe("<a>删除</a>") list_display = ["title", "price", "publish", "pub_date", "show_authors",delbtn,a_link,b_link] # 展现书的名字 #给模型类注admin admin.site.register(Book,Bookconfig) admin.site.register(Publish) admin.site.register(Author) admin.site.register(AuthorDetail)
效果:

知识点补充:
from app1 import models
1.models.Book._meta.model_name
得到模型类 名的小写:'book'
2.models.Book._meta.app_label
得到模型类所在app 小写名 :'app1'
admin 组件源码解析过程:
admin源码解析: 1 启动所有app下的admin.py文件 autodiscover_modules('admin', register_to=site) 2 注册模型类 admin.site: AdminSite的单例对象 admin.site.register(Book,BookConfig) admin.site.register(Author) class ModelAdmin(): pass class AdminSite(): def __init(): self._registry = {} # model_class class -> admin_class instance def register(self, model_or_iterable, admin_class=None): admin_class = admin_class or ModelAdmin self._registry[model] = admin_class(model, self) 3 基于二级分发设计url路由 path('index/', views.index), path('index/',([ path('test01/', test01), path('test02/', test02), ],None,None)), # 二级分发 path('index/',([ path('name/', ([ path('alex/', test01), path('egon/', test02), ],None,None)), path('shop/', ([ path('apple/', test03), path('xiaomi/', test04), path('huawei/', test05), ],None,None)), ],None,None)),
二级分发的应用:
初始 分发原理: path("index",视图函数)或 path( "index" , ( get_urls(), None , None) )
#admin 中 的: def get_urls(): tmp =[ ] for model, config_obj in admin.site._registry.items(): model_name=model._meta.model_name app_label = model._meta.app_label tmp.append( path("%s/%s/"%(app_label,model_name),config_obj.urls) ) return tmp #增删改查视图函数,此函数可以放在 模型类对应的配置类中放此函数 def get_urls(self): tmp=[ path(" " ,self.list_view ), path("add/'',self.add_view), path( "(d+)/change/" , self.change_view ) path( "(d+)/delete/", self.delete_view ) ] return tmp
@property
def urls(self):
return self.get_urls(),NOne,None)
