admin是Django自带的数据库管理工具,是一个app
在admin.py中可以自己定制类来使admin数据库管理页面展现自己想要查看的信息
models.py
from django.db import models # Create your models here. class Book(models.Model): title = models.CharField(max_length=32) price = models.DecimalField(max_digits=6, decimal_places=2) pub_date = models.DateField() authors = models.ManyToManyField(to="Author") def __str__(self): return self.title class Author(models.Model): name = models.CharField(max_length=32) def __str__(self): return self.name
admin.py
from django.contrib import admin from app01.models import * # Register your models here. class BookConfig(admin.ModelAdmin): """自定制类 使得在admin数据库管理页面可以看到自己想要看的信息""" list_display = ["title", "price", "pub_date"] # 多对多字段不可以用于此处 list_display_links = ["title"] # 设置可链接的字段 设置后,点击该字段便可以进入编辑页面 list_filter = ["pub_date"] # 以所设置的字段作为筛选器 进行记录查询 list_editable = ["price"] # 设置可编辑字段,注意:如果在list_display_links中设置了的字段,在此处不可以再设置 search_fields = ["title", "price"] # 设置检索字段(模糊查询:输入关键字即可查询) date_hierarchy = "pub_date" # 过滤日期 # action:批量操作记录 def func(self, request, queryset): # request:请求 queryset:所选中的那些你想要操作的数据 print(self, request, queryset) # 对选中记录作操作: queryset.update(pub_date="2012-1-1") # 将所选记录的出版日改为2012年1月1日 func.short_description = "出版日改为2012年1月1日" actions = [func,] fields = ["title", "price", "pub_date", "authors"] # 在添加记录的页面显示的字段 # exclude = ["pub_date"] # 在添加记录的页面不显示的字段,与fields相反 ordering = ["id"] # 按id升序排列 降序用["-id"] admin.site.register(Book, BookConfig) # 源码:register(self, model_or_iterable, admin_class=None, **options) # model_or_iterable=Book, admin_class=BookConfig print(admin.site._registry) admin.site.register(Author)