【Django】当大型项目采用Django框架对于QueryDict以及模板的表单在Admin 管理工具的使用

简介: 【Django】当大型项目采用Django框架对于QueryDict以及模板的表单在Admin 管理工具的使用

QueryDict

在HttpRequest对象中,GET和POST属性是django.http的实例。QueryDict类。
QueryDict是一个用户定义的类,类似于字典。它用于处理单个键对应多个值的情况。
QueryDict实现所有标准字典方法。它还包括一些独特的方法:

>>> q = QueryDict('a=1')

>>> q = q.copy() # to make it mutable

>>> q.update({'a': '2'})

>>> q.getlist('a')

 ['1', '2']

>>> q['a'] # returns the last

['2']

表单

在模板的末尾,我们添加了一个rlt令牌,为表处理结果预留空间。
表后面还有一个标签{%csrf_token%}。csrf的全称是跨站点请求伪造。这是Django提供的防止伪装提交请求的功能。POST方法提交的表单必须具有此标签。
在HelloWorld目录中创建一个search2.py文件,并使用search_post函数处理post请求:

from django.http import HttpResponse
from django.shortcuts import render
# 表单
def search_form(request):
    return render(request, 'search_form.html')
 
# 接收请求数据
def search(request):  
    request.encoding='utf-8'
    if 'q' in request.GET and request.GET['q']:
        message = '你搜索的内容为: ' + request.GET['q']
    else:
        message = '你提交了空表单'
    return HttpResponse(message)

HTTP协议在“请求-应答”模式下工作。当客户发送请求时,可以将数据附加到请求中。通过解析请求,服务器可以从客户端获取数据,并根据URL提供特定服务。

HttpRequest 对象

在这里插入图片描述

def runoob(request):
    return redirect("/index/")

view函数,简称view,是一个简单的Python函数,它接受Web请求并返回Web响应。
响应可以是HTML页面、404错误页面、重定向页面、XML文档或图像
无论视图包含什么逻辑,都必须返回响应。代码可以在任何地方编写,只要它在Python目录中,通常在项目视图Py文件中。
每个视图函数负责返回一个HttpResponse对象,该对象包含生成的响应。
视图层中有两个重要的对象:请求对象和响应对象。

Admin 管理工具

我们可以自定义管理页面以替换默认页面。例如,上面的“添加”页面。我们只想显示姓名和电子邮件部分。修改TestModel/admin.py

from django.contrib import admin
from TestModel.models import Test,Contact,Tag
 
# Register your models here.
class ContactAdmin(admin.ModelAdmin):
    fields = ('name', 'email')
 
admin.site.register(Contact, ContactAdmin)
admin.site.register([Test, Tag])

上面的代码定义了一个ContactAdmin类来解释管理页面的显示格式。
字段属性定义要显示的字段。
因为这个类对应于Contact数据模型,所以我们需要在注册时一起注册它们。显示效果如下:
在这里插入图片描述

from django.contrib import admin
from TestModel.models import Test,Contact,Tag
 
# Register your models here.
class ContactAdmin(admin.ModelAdmin):
    fieldsets = (
        ['Main',{
            'fields':('name','email'),
        }],
        ['Advance',{
            'classes': ('collapse',), # CSS
            'fields': ('age',),
        }]
    )
 
admin.site.register(Contact, ContactAdmin)
admin.site.register([Test, Tag])

上面的联系人是标记的外部键,因此它具有外部引用关系。
在默认页面显示中,不能将两者分开以反映其相关性。我们可以使用内联显示将标记附加到联系人的编辑页面。
修改TestModel/admin.py:

from django.contrib import admin
from TestModel.models import Test,Contact,Tag
 
# Register your models here.
class TagInline(admin.TabularInline):
    model = Tag
 
class ContactAdmin(admin.ModelAdmin):
    inlines = [TagInline]  # Inline
    fieldsets = (
        ['Main',{
            'fields':('name','email'),
        }],
        ['Advance',{
            'classes': ('collapse',),
            'fields': ('age',),
        }]
 
    )
 
admin.site.register(Contact, ContactAdmin)
admin.site.register([Test])

原因是MySQL客户端目前只支持Python 3.4,因此如果您使用更高版本的Python,则需要按如下方式进行修改:
在这里插入图片描述

通过错误消息Py文件的文件路径,在…site packages django-2.0-py3.6.eggDjango-db-backends-mysql的路径中找到基,注释掉两行代码(代码位于文件的开头):

if version < (1, 3, 13):
    raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__)

通常,单击报告错误的代码文件的路径信息将自动跳转到错误文件中的行数。此时,我们将注释掉错误文件中的行数。
此时,数据库runoob将为book创建app01_Table。
接下来,我们将视图添加到app01项目Py和模型Py文件app01项目目录结构中。

from django.contrib import admin
from django.urls import path
from . import views
 
urlpatterns = [
    path('add_book/', views.add_book),
]

在这里插入图片描述
filter()方法用于查询限定数据。
返回的数据是QuerySet类型,类似于列表。它包含满足条件的模型类的对象。可以使用索引下标来检索模型类的对象。
Pk=3意味着主键=3,这相当于id=3。
由于id在pychar中具有特殊含义,它指的是内存地址的内置函数id(),因此使用pk。

from django.shortcuts import render,HttpResponse
from app01 import models 
def add_book(request):
    books = models.Book.objects.filter(pk=5)
    print(books)
    print("//////////////////////////////////////")
    books = models.Book.objects.filter(publish='菜鸟出版社', price=300)
    print(books, type(books))  # QuerySet类型,类似于list。
    return HttpResponse("<p>查找成功!</p>")

在这里插入图片描述

相关文章
|
9天前
|
Java C++ Python
django 模板 过滤器
django 模板 过滤器
|
2月前
|
存储 缓存 中间件
Django 框架中 Session 的用法
【8月更文挑战第30天】
18 6
|
2月前
|
前端开发 JavaScript 数据库
python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器
python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器
|
2月前
|
JSON 前端开发 API
Django 后端架构开发:通用表单视图、组件对接、验证机制和组件开发
Django 后端架构开发:通用表单视图、组件对接、验证机制和组件开发
47 2
|
2月前
|
JSON 数据处理 API
Django后端架构开发:视图与模板的正确使用
Django后端架构开发:视图与模板的正确使用
14 1
|
2月前
|
数据采集 Python
Django 表单
【8月更文挑战第24天】
27 3
|
2月前
|
前端开发 Python
Django模板
【8月更文挑战第19天】
28 3
|
2月前
|
Python
Django表单组件
【8月更文挑战第20天】
26 1
|
2月前
|
前端开发 JavaScript 数据处理
Django的表单处理
【8月更文挑战第16天】
16 2
|
2月前
|
API Java 数据库连接
从平凡到卓越:Hibernate Criteria API 让你的数据库查询瞬间高大上,彻底告别复杂SQL!
【8月更文挑战第31天】构建复杂查询是数据库应用开发中的常见需求。Hibernate 的 Criteria API 以其强大和灵活的特点,允许开发者以面向对象的方式构建查询逻辑,同时具备 SQL 的表达力。本文将介绍 Criteria API 的基本用法并通过示例展示其实际应用。此 API 通过 API 构建查询条件而非直接编写查询语句,提高了代码的可读性和安全性。无论是简单的条件过滤还是复杂的分页和连接查询,Criteria API 均能胜任,有助于提升开发效率和应用的健壮性。
67 0