from django.contrib import admin admin.site.site_header = '高血压药物相互作用信息管理后台' # 设置header admin.site.site_title = '高血压药物相互作用信息管理后台' # 设置title admin.site.index_title = '高血压药物相互作用信息管理后台' from .models import Drug,DrugInteraction,Message class DrugAdmin(admin.ModelAdmin): list_display = ['id','drug_name'] search_fields = ['drug_name']
时间: 2024-02-01 19:04:54 浏览: 142
这段代码是用来创建一个 Django 后台管理界面的。其中:
- `admin.site.site_header` 设置后台管理界面的头部标题;
- `admin.site.site_title` 设置后台管理界面的浏览器标题;
- `admin.site.index_title` 设置后台管理界面的首页标题;
- `Drug`、`DrugInteraction`、`Message` 是需要在后台管理的模型;
- `DrugAdmin` 是用来定制模型在后台管理界面的显示方式,其中`list_display` 设置要显示的字段,`search_fields` 设置要搜索的字段。
相关问题
在django项目中为我的高血压网站建一个后台系统,后台导航栏内容包括药品信息管理菜单,下边设置两个下拉菜单显示药品信息管理和药品相互作用管理内容,药品信息管理页面对mysql库drug_db中的drug_list表(id drug_name)进行增删改查操作,药品相互作用信息管理负责对mysql库drug_db中的drug_interaction(drug_id drug1 drug2 interaction )中的内容进行增删改查操作
可以使用Django Admin来创建后台系统,以下是一些大致的步骤:
1. 在你的Django项目的settings.py文件中,添加以下代码:
```python
INSTALLED_APPS = [
# ... 其他的app
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]
# 配置Django Admin的标题和页面头部
ADMIN_SITE_HEADER = "高血压网站管理"
ADMIN_SITE_TITLE = "高血压网站"
```
2. 创建一个app(如果还没有)用于存放后台系统相关的代码,例如命名为backend。
3. 在backend目录下创建admin.py文件,并添加以下代码:
```python
from django.contrib import admin
from .models import DrugList, DrugInteraction
# 注册DrugList模型到Django Admin
class DrugListAdmin(admin.ModelAdmin):
list_display = ('id', 'drug_name') # 定义在列表中显示哪些字段
search_fields = ('drug_name',) # 定义可以搜索哪些字段
admin.site.register(DrugList, DrugListAdmin)
# 注册DrugInteraction模型到Django Admin
class DrugInteractionAdmin(admin.ModelAdmin):
list_display = ('id', 'drug_id', 'drug1', 'drug2', 'interaction')
search_fields = ('drug1', 'drug2', 'interaction')
admin.site.register(DrugInteraction, DrugInteractionAdmin)
```
4. 在backend目录下创建urls.py文件,并添加以下代码:
```python
from django.urls import path, include
from django.contrib import admin
urlpatterns = [
path('admin/', admin.site.urls),
]
```
5. 在你的项目根目录下运行命令行,输入以下命令创建DrugList和DrugInteraction模型:
```python
python manage.py makemigrations backend
python manage.py migrate
```
6. 启动Django服务器,访问http://localhost:8000/admin/,使用超级用户登录,你就可以看到Django Admin的后台系统了。
7. 在后台系统中,你可以在药品信息管理菜单下进行DrugList模型的增删改查操作,在药品相互作用管理菜单下进行DrugInteraction模型的增删改查操作。
{% extends "admin/base.html" %} {% block content %} <div class="container-fluid"> <div class="row"> <div class="col-md-6"> <h2>药品列表</h2> <table class="table"> <thead> <tr> <th>ID</th> <th>药品名称</th> <th>操作</th> </tr> </thead> <tbody> {% for drug in drugs %} <tr> <td>{{ drug.id }}</td> <td>{{ drug.drug_name }}</td> <td> <a href="{% url 'admin:drug_db_drug_list_change' drug.id %}" class="btn btn-primary btn-sm">编辑</a> <form action="{% url 'admin:drug_db_drug_list_delete' drug.id %}" method="post" class="d-inline"> {% csrf_token %} <button class="btn btn-danger btn-sm">删除</button> </form> </td> </tr> {% empty %} <tr> <td colspan="3">暂无药品</td> </tr> {% endfor %} </tbody> </table> <a href="{% url 'admin:drug_db_drug_list_add' %}" class="btn btn-success">添加新药品</a> </div> <div class="col-md-6"> <h2>药品相互作用</h2> <table class="table"> <thead> <tr> <th>ID</th> <th>药品1</th> <th>药品2</th> <th>相互作用</th> <th>操作</th> </tr> </thead> <tbody> {% for interaction in interactions %} <tr> <td>{{ interaction.id }}</td> <td>{{ interaction.drug1 }}</td> <td>{{ interaction.drug2 }}</td> <td>{{ interaction.interaction }}</td> <td> <a href="{% url 'admin:drug_db_drug_interaction_change' interaction.id %}" class="btn btn-primary btn-sm">编辑</a> <form action="{% url 'admin:drug_db_drug_interaction_delete' interaction.id %}" method="post" class="d-inline"> {% csrf_token %} <button class="btn btn-danger btn-sm">删除</button> </form> </td> </tr> {% empty %} <tr> <td colspan="5">暂无药品相互作用</td> </tr> {% endfor %} </tbody> </table> <a href="{% url 'admin:drug_db_drug_interaction_add' %}" class="btn btn-success">添加新药品相互作用</a> </div> </div> </div> {% endblock %} 为上述代码设置相应的视图和URL配置,并将这些视图和操作注册到Django admin页面中。
首先,需要定义视图函数来渲染药品列表和药品相互作用列表的页面。可以使用Django的通用视图类(Generic Views)来完成。
```python
from django.views.generic import TemplateView
class DrugListView(TemplateView):
template_name = "admin/drug_db/drug_list.html"
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
context["drugs"] = Drug.objects.all()
context["interactions"] = DrugInteraction.objects.all()
return context
```
上述视图函数将会渲染名为 `drug_list.html` 的模板文件,并且会将所有的药品和药品相互作用传递给模板。
接着,需要定义URL配置来匹配请求并将其分配给对应的视图函数。
```python
from django.urls import path
from .views import DrugListView
app_name = "drug_db"
urlpatterns = [
path("", DrugListView.as_view(), name="drug_list"),
]
```
最后,需要将上述URL配置和视图函数注册到Django admin页面中。
```python
from django.contrib import admin
from django.urls import path, include
from drug_db.views import DrugListView
admin.site.site_header = "药品管理系统"
admin.site.site_title = "药品管理系统"
admin.site.index_title = "欢迎使用药品管理系统"
urlpatterns = [
path("admin/", admin.site.urls),
path("drug_db/", include("drug_db.urls")),
]
admin.site.register_view("drug_db/drug_list/", view=DrugListView.as_view(), name="drug_db_drug_list")
```
上述代码将会在Django admin页面的左侧菜单中添加一个名为“药品列表”的链接,点击链接将会显示药品列表和药品相互作用列表的页面。
阅读全文