django -xadmin 详解 功能实现及orm 的复习

django 在xadmin中自定义内容的变量及优化汇总

 

一: 首先下载xadmincss

 

pip install git+git://github.com/sshwsfc/xadmin.git@django2

 

 

而后在项目的settings.py中添加以下配置python

 

 

INSTALLED_APPS = [
    .....
    'xadmin',
    'crispy_forms',
    'reversion'
]

 

 

 

假如你是用的MySql数据库,进行以下配置mysql

 

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'mydb',
        'USER': 'root',
        'PASSWORD': '123456',
        'HOST': '139.107.172.158',
        'PORT': '3306',
    }
}

 

 

 

同时能够把语言改为中文,时区改为上海git

 

LANGUAGE_CODE = 'zh-Hans'

TIME_ZONE = 'Asia/Shanghai'

USE_TZ = False # 若是没有国际化的需求写False,不然数据中插入时间时,有警告。

 

 

 

下一步配置路由,打开项目的urls.py作以下修改github

 

urlpatterns = [
    ......
    path('admin/', xadmin.site.urls),
]

 

 

 

 

ok ! 你能够用了ajax

 

一、list_display 指定xadmin中须要显示哪些字段信息,以列表显示sql

list_display = ('first_name', 'last_name', 'email')数据库

二、search_fields 指定哪些字段信息能够被搜索django

search_fields = ('first_name', 'last_name')bash

三、list_filter 添加哪些字段须要进行过滤显示(添加过滤器)

list_filter = ('publication_date',) #添加过滤(这里是过滤日期) 

四、date_hierarchy 添加日期过滤器,该字段只能是日期类型

date_hierarchy = 'publication_date' #过滤(日期的另一种过滤方式,能够添加后看一下) 

五、ordering 显示的列表以什么进行排序 ,加‘-’表示降序

ordering = ('-publication_date',) #排序(这里以日期排序,加‘-’表示降序) 

六、fields 排除一些不想被其余人编辑的fields,不包含在内的字段不能编辑

fields = ('title', 'authors', 'publisher') 

七、filter_horizontal 从‘多选框’的形式改变为‘过滤器’的方式,水平排列过滤器,必须是一个 ManyToManyField类型,且不能用于 ForeignKey字段,默认地,管理工具使用下拉框 来展示外键 字段

 

八、filter_vertical #同上filter_horizontal,垂直排列过滤器

filter_vertical = ('authors',) 

九、raw_id_fields 将ForeignKey字段从‘下拉框’改变为‘文本框’显示

raw_id_fields = ('publisher',) 

十、list_editable 列表显示的时候,指定的字段能够直接页面一键编辑

list_editable = ['csdevice'] 

十一、model_icon 指该表菜单的icon样式

model_icon = 'fa fa-user-secret' 

十二、readonly_fields 指定一些字段为只读,不可修改

readonly_fields = ('cservice',) 

1三、exclude 在编辑和查看列表时指定不显示的字段

exclude = ['cservice'] 

1四、style_fields 指定xadmin插件的样式

style_fields = {'csdevice': 'm2m_transfer','csservice': 'ueditor',} 

1五、refresh_times 后台可选择10秒刷新一次或者60秒刷新一次以下

refresh_times = [10, 60]

1六、show_detail_fields 在指定的字段后添加一个显示数据详情的一个按钮

show_detail_fields=['ttdsn'] 

1七、relfield_style后台自定义不是下拉选择框,而是搜索框(解决了为何用户不是下拉框的问题。。)

relfield_style = 'fk-ajax' 

1八、修改 xadmin 的主题 、title、header、菜单样式

from xadmin import views class BaseSetting(object): enable_themes = True #开启主题选择 use_bootswatch = True class GlobalSettings(object): site_title = "老眼售后管理系统" #设置左上角title名字 site_footer = "lybbn" #设置底部关于版权信息 #设置菜单缩放 menu_style = "accordion" #设置菜单样式 xadmin.site.register(views.BaseAdminView, BaseSetting) xadmin.site.register(views.CommAdminView, GlobalSettings) 

1九、页面显示中文和时区

在settings.py中配置

LANGUAGE_CODE = 'zh-hans' TIME_ZONE = 'Asia/Shanghai' 

20、设置xadmin的app标题,在apps.py文件中,添加verbose_name = "客户管理"

from django.apps import AppConfig class CustomersConfig(AppConfig): name = 'apps.customers' verbose_name = "客户管理"










自定制: action 的使用
能够经过orm 进行跨表或者 当前表计算

 

 

 

 

 list_display 设定 字段

obj 是当前操做行的字段. 能够 经过orm 跨表  或者当前表进行计算设定

 

 

 

 

 

 

图表的使用

图表主要分红 折线图和柱形图 ,目前还没找到怎么改 只能用默认样式.

等着研究研究怎么把echarts 加入到xadmin 中 使用

 

   data_charts = {
        "user_count": {'title': u"sc金额变化表折现表",
                       "x-field": "num",
                       "y-field": ("dqmoney",),
                       },
        "num_count": {'title': u"sc金额变化表1柱形表",
                       "x-field": "num",
                       "y-field": ("dqmoney",),
                      'option': {
                          "series": {"bars": {"align": "center", "barWidth": 0.8, "show": True}},
                          "xaxis": {"num": "count", "dqmoney": "categories"}
                      },
                       },
    }

 

 

 

 

 

 

总体代码

# -*- coding: utf-8 -*-
# @Time    : 2019/6/22 14:11
# @Author  : Endless-cloud
# @Site    : 
# @File    : adminx.py
# @Software: PyCharm
'''
         ┏┓  ┏┓+ +
        ┏┛┻━━━┛┻┓ + +
        ┃      ┃  
        ┃   ━   ┃ ++ + + +
        ████━████  ┃+
        ┃       ┃ +
        ┃   ┻   ┃
        ┃      ┃ + +
        ┗━┓   ┏━┛
          ┃   ┃           
          ┃   ┃ + + + +
          ┃   ┃    Code is far away from bug with the animal protecting       
          ┃   ┃ +     神兽保佑,代码无bug  
          ┃   ┃
          ┃   ┃  +         
          ┃    ┗━━━┓ + +
          ┃        ┣┓
          ┃       ┏┛
          ┗┓┓┏━┳┓┏┛ + + + +
           ┃┫┫ ┃┫┫
           ┗┻┛ ┗┻┛+ + + +
 '''
import xadmin
#导入xadmin 文件
from .models import Sc_msg
#导入模型类
# from xadmin.plugins.actions import BaseActionView
# class MyAction(BaseActionView):           # action类
#     action_name = 'My_action'
#     description = 'This is my action button'
#     model_perm = 'change'
#
#     def do_action(self, queryset):
#         for obj in queryset:
#         return HttpResponse(obj)
#
#
# class MyModelAdmin(object):
#
#     actions = [MyAction, ]




class Sc_Msgxadmin(object):

    # 自定制action
    def pacth_init(self, request, queryset):
        print('hahaha',request,queryset)
        queryset.update(dqmoney=0)
    pacth_init.short_description ='价格初始化'

    actions =[pacth_init]


    #自定制list_display
    def math_sc(self,obj):
        print(obj.jhhl,obj.sjhl)
        # num1 =obj.sjhl/obj.jhhl
        num1 =obj.jhhl/obj.sjhl
        bb = "%.2f%%" % (num1 * 100)
        return bb

    math_sc.short_description = '总诊断量'


    list_display=['math_sc','hkdate','khname','dqmoney','jhhl','sjhl','hkhll','wwccy','yqhk','cyyi']# 设置默认展现列
    list_editable=['khname','dqmoney'] #设置哪行能够直接编辑
    search_fields = ['khname','dqmoney'] # 设置搜索
    ordering =['-num'] # 设置排序
    list_filter = ['khname','dqmoney']  # 设置过滤项
    # reversion_enable = True
    readonly_fields = ['num'] # 锁定num 不容许修改
    exclude = ['num'] # 在编辑或者查看的时候不显示某个字段
    show_detail_fields = ['khname']#在指定的字段后添加一个显示数据详情的一个按钮
    refresh_times = [10, 60]  # 自动刷新时间
    style_fields = {'dqmoney': 'm2m_transfer', 'dqmoney': 'ueditor', }  # 字段显示样式
    aggregate_fields = {"dqmoney": "sum"} #  列聚合,在list表格下面会增长一行统计的数据,可用的值:"count","min","max","avg",  "sum"
# 添加数据时候,一步一步提供数据,分块显示
    model_icon = 'fa fa-home' # 菜单的样式
    #
    #
    # grid_layouts = ("cyyi",)  ##列表的布局方式,是以表格一行一条的方式仍是相似于缩略图的方式展现的
    data_charts = {
        "user_count": {'title': u"sc金额变化表折现表",
                       "x-field": "num",
                       "y-field": ("dqmoney",),
                       },
        "num_count": {'title': u"sc金额变化表1柱形表",
                       "x-field": "num",
                       "y-field": ("dqmoney",),
                      'option': {
                          "series": {"bars": {"align": "center", "barWidth": 0.8, "show": True}},
                          "xaxis": {"num": "count", "dqmoney": "categories"}
                      },
                       },
    }
    # data_charts = {
    #     "user_count": {'title': u"sc到期货款",
    #                    "x-field": "num",
    #                    "y-field": ("jhhl",),
    #                    },
    # }



xadmin.site.register(Sc_msg,Sc_Msgxadmin)





import xadmin
from xadmin import views



# 配置后台主题
class BaseSetting(object):
    enable_themes = True
    use_bootswatch = True


xadmin.site.register(views.BaseAdminView, BaseSetting)
# 后台系统名称页脚设置、设置后台菜单为收缩样式
class GlobalSetting(object):
    site_title = 'sc系统'
    site_footer = 'sc系统'
    menu_style = 'accordion'


xadmin.site.register(views.CommAdminView, GlobalSetting)

样子

相关文章
相关标签/搜索