基于Django的Admin后臺(tái)實(shí)現(xiàn)定制簡(jiǎn)單監(jiān)控頁(yè)
我們使用Django的Admin二次定制一個(gè)圖形化界面,首先我們把語(yǔ)言設(shè)置為中文簡(jiǎn)體.
修改: settings.py LANGUAGE_CODE = 'zh-hans' TIME_ZONE = 'Asia/Shanghai' 修改: apps.py from django.apps import AppConfig class MywebConfig(AppConfig): name = 'MyWeb' verbose_name = "服務(wù)器參數(shù)收集"
接著我們來(lái)定義models.py數(shù)據(jù)庫(kù)模型,定義基本的數(shù)據(jù)查詢.
from django.db import models from django.utils.html import format_html import datetime STATUS_CHOICES = (('d', '在用設(shè)備'), ('p', '下線設(shè)備'), ('w', '損壞設(shè)備'),) # 定義主機(jī)基本信息表 class HostInfoDB(models.Model): id = models.AutoField(primary_key=True) # HostAddr = models.TextField(max_length=128,verbose_name="主機(jī)地址") HostAddr = models.CharField(max_length=128, verbose_name="主機(jī)地址") HostName = models.CharField(max_length=128, verbose_name="主機(jī)名稱") HostType = models.CharField(max_length=128, verbose_name="系統(tǒng)類型") HostPosition = models.CharField(max_length=128, verbose_name="機(jī)房位置") HostPlatform = models.CharField(max_length=128, verbose_name="所屬平臺(tái)") HostGroup = models.CharField(max_length=128, verbose_name="分組") HostDataTime = models.DateTimeField(verbose_name="檢查日期") HostUser = models.CharField(max_length=64, verbose_name="負(fù)責(zé)人") hostStats = models.CharField(max_length=1, choices=STATUS_CHOICES, verbose_name="設(shè)備狀態(tài)") def __str__(self): return self.HostName # 用于給本表指定別名,這樣前端就不是英文的了 class Meta(): verbose_name = "設(shè)備清單" verbose_name_plural = "設(shè)備清單" # 設(shè)備再用狀態(tài) def Status(self): if self.hostStats == 'd': format_td = format_html('<span style="padding:2px;background-color:green;color:white">在用設(shè)備</span>') elif self.hostStats == 'p': format_td = format_html('<span style="padding:2px;background-color:yellow;color:black">下線設(shè)備</span>') elif self.hostStats == 'w': format_td = format_html('<span style="padding:2px;background-color:red;color:white">損壞設(shè)備</span>') return format_td Status.short_description = "當(dāng)前狀態(tài)" # 指定Ping檢測(cè)結(jié)果表 class HostPingInfo(models.Model): id = models.AutoField(primary_key=True) HostAddr = models.CharField(max_length=128, verbose_name="主機(jī)地址") flage = models.CharField(max_length=64) class Meta(): verbose_name = "存活檢測(cè)" verbose_name_plural = "存活檢測(cè)" def Status(self): if self.flage == "True": ret = "已連接" color = "green" return format_html('<span style="color:{};">{}</span>',color,ret,) elif self.flage == "False": ret = "未連接" color = "red" return format_html('<span style="color:{};">{}</span>', color, ret,) Status.short_description = "狀態(tài)" # 定義CPU/內(nèi)存利用率數(shù)據(jù)表結(jié)構(gòu) class HostCPUOrMemInfo(models.Model): id = models.AutoField(primary_key=True) HostAddr = models.CharField(max_length=128, verbose_name="主機(jī)地址") Cpu_Count = models.IntegerField() Mem_Count = models.IntegerField() class Meta(): verbose_name = "CPU內(nèi)存性能" verbose_name_plural = "CPU內(nèi)存性能" def Cpu_Speed(self): return format_html('<progress max="100" value="{}"></progress>',self.Cpu_Count) def Mem_Speed(self): return format_html('<progress max="100" value="{}"></progress>',self.Mem_Count) def Check(self): return format_html('<a href="/admin/MyWeb/hostdb/{}/change/" rel="external nofollow" >查看</a>',self.id) Cpu_Speed.short_description = "CPU利用率" Mem_Speed.short_description = "Mem利用率"
繼續(xù)定制admin.py
并與上方的數(shù)據(jù)庫(kù)視圖相交互.
from django.contrib import admin from MyWeb.models import * # 必須繼承ModelAdmin基類,才可以調(diào)整參數(shù),HostDB則是你的表的名稱 @admin.register(HostInfoDB) class MyAdmin(admin.ModelAdmin): admin.site.site_title="后臺(tái)管理" admin.site.site_header = "自動(dòng)化監(jiān)控平臺(tái)" # list_display = 你需要展示的字段應(yīng)該寫在這里,此處是數(shù)據(jù)庫(kù)中的字段 list_display = ("HostAddr","HostName","HostType","HostPosition","HostDataTime","HostPlatform","HostGroup","HostUser","Status") # search_fields = 用于添加一個(gè)搜索框,此處作為查詢條件 #search_fields = ("HostAddr","HostType","Status",) # list_filter = 設(shè)置一個(gè)過(guò)濾器,此處是過(guò)濾條件 list_filter = ("HostAddr","HostGroup",) # ordering = 設(shè)置一個(gè)排序條件,此處是以id作為排序依據(jù) ordering = ("id",) #list_per_page = 設(shè)置每頁(yè)顯示多少條記錄,默認(rèn)是100條 list_per_page = 10 #list_editable = 設(shè)置默認(rèn)可編輯字段 #list_editable = ("HostName",) # date_hierarchy = 顯示詳細(xì)時(shí)間分層篩選 date_hierarchy = 'HostDataTime' # readonly_fields = 可以設(shè)置只讀字段,就是無(wú)法修改的字段 #readonly_fields = ("hostCPU","hostMEM",) # 定義Ping檢測(cè)顯示字段 @admin.register(HostPingInfo) class MyAdmin(admin.ModelAdmin): list_display = ("HostAddr","flage","Status") # 定義內(nèi)存CPU利用率字段 @admin.register(HostCPUOrMemInfo) class MyAdmin(admin.ModelAdmin): list_display = ("id","HostAddr","Cpu_Count","Cpu_Speed","Mem_Count","Mem_Speed","Check")
保存后直接執(zhí)行命令,完成命令行建表操作.
python manage.py makemigrations python manage.py migrate python manage.py createsuperuser
保存后啟動(dòng),Django并訪問(wèn)http://127.0.0.1:8000/admin登錄后我們依次看一下定制效果.
主頁(yè)中的展示效果如下.
當(dāng)我們需要增加自定義動(dòng)作時(shí),可以這樣寫,我們以HostCPUOrMemInfo
為例
# 定義內(nèi)存CPU利用率字段 @admin.register(HostCPUOrMemInfo) class MyAdmin(admin.ModelAdmin): list_display = ("id","HostAddr","Cpu_Count","Cpu_Speed","Mem_Count","Mem_Speed") # 添加的自定義動(dòng)作,此處可執(zhí)行操作 def func(self, request, queryset): # 此處可以寫一些執(zhí)行動(dòng)作 print(self, request, queryset) func.short_description = "自定義active動(dòng)作" actions = [func, ] # Action選項(xiàng)都是在頁(yè)面上方顯示 actions_on_top = True # Action選項(xiàng)都是在頁(yè)面下方顯示 actions_on_bottom = False # 是否顯示選擇個(gè)數(shù) actions_selection_counter = True
以上就是基于Django的Admin后臺(tái)實(shí)現(xiàn)定制簡(jiǎn)單監(jiān)控頁(yè)的詳細(xì)內(nèi)容,更多關(guān)于Django Admin后臺(tái)定制監(jiān)控頁(yè)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python利用Excel讀取和存儲(chǔ)測(cè)試數(shù)據(jù)完成接口自動(dòng)化教程
這篇文章主要介紹了python利用Excel讀取和存儲(chǔ)測(cè)試數(shù)據(jù)完成接口自動(dòng)化教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04Python使用Pandas生成日?qǐng)?bào)的實(shí)現(xiàn)代碼
Pandas是Python中一個(gè)強(qiáng)大的數(shù)據(jù)處理庫(kù),它提供了許多功能強(qiáng)大的數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)分析工具,在本文中,我們將介紹Pandas的基本概念和如何使用它生成一個(gè)包含今天到未來(lái)20個(gè)工作日的日期列表的Excel文件,需要的朋友可以參考下2023-11-11使用python進(jìn)行文本預(yù)處理和提取特征的實(shí)例
今天小編就為大家分享一篇使用python進(jìn)行文本預(yù)處理和提取特征的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06Python multiprocessing 進(jìn)程間通信方式實(shí)現(xiàn)
本文主要介紹了Python multiprocessing 進(jìn)程間通信方式實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02Python urllib2運(yùn)行過(guò)程原理解析
這篇文章主要介紹了Python urllib2運(yùn)行過(guò)程原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06Python實(shí)現(xiàn)考試自動(dòng)答題的腳本分享
最近這段時(shí)間天氣正正好,不冷不熱,是學(xué)習(xí)考駕照的好時(shí)機(jī)。為了幫助大家能夠順利獲得駕照,小編為大家準(zhǔn)備了駕照考試的自動(dòng)答題小程序,希望對(duì)大家有所幫助2023-03-03Python實(shí)現(xiàn)名片管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)名片管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02