django admin添加自己的页面

建立模型

如果要单独建一个页面,用于展示model的数据,可以新建一个model,继承自要展示的那个类

py 复制代码
class ViewsByDayModel(ViewsByDay): # 父类为要展示的model类
    class Meta:
        proxy = True # 使用代理
        verbose_name = '每日浏览次数统计'
        verbose_name_plural = verbose_name

代理模型 proxy = True 。允许为一个已存在的模型创建一个新的类,这个新类在数据库中没有与之对应的表,但它可以覆盖原始模型的行为,如改变默认的Manager、添加或覆盖方法、改变模型的Meta属性等。代理模型在Django的admin后台中特别有用,因为它允许你为同一个数据表提供不同的管理界面和行为。

admin中注册模型

py 复制代码
@admin.register(ViewsByDayModel)
class ViewsByDayAdmin(admin.ModelAdmin):
    change_list_template = 'admin/admin_log.html'
    
    def changelist_view(self, request, extra_context=None):
        log_file = 'log/debug.log'
        log_content = []
        log_content += [line for line in open(log_file, 'r', encoding='UTF-8')]
        extra_context = extra_context or {}
        extra_context["context"] = log_content
        response = super().changelist_view(
            request,
            extra_context=extra_context
        )
        return response

建立admin模板

具体见:https://docs.djangoproject.com/zh-hans/4.2/ref/contrib/admin/#overriding-admin-templates

CSS 变量的列表在 django/contrib/admin/static/admin/css/base.css 中定义。

在admin中指定自定义的模板路径 ModelAdmin.change_list_template¶ 自定义模板的路径,由 changelist_view() 使用。

在官网中介绍的是在extra_context中添加自己要添加的数据

py 复制代码
def change_view(self, request, object_id, form_url="", extra_context=None):
        extra_context = extra_context or {}
        extra_context["osm_data"] = self.get_osm_info()
        return super().change_view(
            request,
            object_id,
            form_url,
            extra_context=extra_context,
        )

而通过测试,在 response.context_data['要添加的数据key'] 中添加数据,也是可以找到的

我是要在后台显示日志中的内容,通过heightlight的代码显示部分

html 复制代码
{% extends 'admin/change_list.html' %}
{% load static %}
{% block content_title %}
    <!-- ECharts单文件引入 -->
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.18.1/styles/default.min.css">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.18.1/highlight.min.js"></script>
{% endblock %}
 
{% block result_list %}
管理领导浏览查看(循环显示,不做统计)
<script>hljs.initHighlightingOnLoad();</script>
<pre><code>
{% for line in context|slice:"::-1" %}{{ line }}{% endfor %}
</code></pre>
{% endblock %}

最终的效果就是把log日志中的内容,展示在后台显示了

欢迎大家在评论中交流提问

相关推荐
心扬12 分钟前
python生成器
开发语言·python
mouseliu17 分钟前
python之二:docker部署项目
前端·python
狂小虎35 分钟前
亲测解决self.transform is not exist
python·深度学习
Python智慧行囊37 分钟前
Python 中 Django 中间件:原理、方法与实战应用
python·中间件·架构·django·开发
深科文库1 小时前
构建 MCP 服务器:第 3 部分 — 添加提示
服务器·python·chatgpt·langchain·prompt·aigc·agi
蓝婷儿1 小时前
6个月Python学习计划 Day 17 - 继承、多态与魔术方法
开发语言·python·学习
Mikhail_G2 小时前
Python应用变量与数据类型
大数据·运维·开发语言·python·数据分析
hello kitty w2 小时前
Python学习(7) ----- Python起源
linux·python·学习
站大爷IP2 小时前
Python文本序列的类型
python