码迷,mamicode.com
首页 > 其他好文 > 详细

Django admin 设置和定制

时间:2018-02-27 11:34:32      阅读:813      评论:0      收藏:0      [点我收藏+]

标签:body   标题   pre   create   length   arch   save   query   data   

models 在 models.py 中定义,每个 model 是一个 class:

from django.db import models
class PerformanceData(models.Model):
    name = models.CharField(name, max_length=200, unique=True)
date = models.DateTimeField(‘date‘)

自定义 object 的显示

def __unicode__(self): # 如果是 python3 使用 __str__
    return u%s %s % (self.name, self.date)

在 admin.py 中定义 PerformanceDataAdmin 继承 admin.ModelAdmin, 进一步对 model 进行设置:

class PerformanceDataAdmin(admin.ModelAdmin):
    list_display=(name, ‘date) # 显示表格的表头
    list_per_page = 50 # 每页显示 50 条记录
    ordering = (-name,) # 用 name 属性排序, ‘-‘ 表示倒序排列
    list_filter =(‘name, ‘date) # 设置过滤器
    search_fields =(name‘, ‘date‘) # 设置搜索框中允许搜索的字段
actions = [add_one_copy,] # 添加一个 action, 需要定义函数 add_one_copy admin.site.site_header
= Test Management‘ # 设置标题 admin.site.site_title = Test Management‘ # 设置标题 admin.site.register(PerformanceData, PerformanceDataAdmin) # 注册

设置字段颜色,在 models.py 中定义新的字段如下:

from django.db import models
from django.utils.html import format_html

class PerformanceData(models.Model):
    name = models.CharField(name, max_length=200, unique=True)
    date = models.DateTimeField(date)
    def colored_name(self):
        if self.name == 1:
            color_code = green
        else:
            color_code = red

        return format_html(
            <span style="color: #{};">{}</span>,
            color_code,
            self.name,
        )

在 admin.py 中需要改为

list_display=(colored_name, date) # 显示表格的表头

更改表头的显示文字

colored_name.short_description = ‘MY_NAME

注意,要先为字段在 models.py 中定义一个类似 colored_name 的方法,并设置 short_description,然后在 admin.py 的 list_display 中使用这个新的方法定义。例如:

class PerformanceData(models.Model):
    name = models.CharField(name, max_length=200, unique=True)
    date = models.DateTimeField(date)
    def short_date(self):
        return self.date
    short_date.short_description = ‘MY_DATE‘
list_display=(colored_name, short_date) # 显示表格的表头

为表格添加 actions

def add_one_copy(modelAdmin, request, queryset):
    add_one_copy.short_description = Select and add one copy
    for i in queryset:
        print(i.date)
class PerformanceDataAdmin(admin.ModelAdmin):
    actions = [add_one_copy,] # 添加一个 action, 需要定义函数 add_one_copy

为 model 添加 create 函数,可以调用这个函数增加新的条目

from django.db import models
from datetime import *

class PerformanceData(models.Model):
    name = models.CharField(name, max_length=200, unique=True)
    date = models.DateTimeField(date)
    @classmethod
    def create(cls, _name, _date):
        obj = cls(name=_name, date=_date)
        return obj
obj = PerformanceData.create(hello, datetime(1980,10,11))
obj.save()

 

Django admin 设置和定制

标签:body   标题   pre   create   length   arch   save   query   data   

原文地址:https://www.cnblogs.com/weiweifeng/p/8477833.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!