前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Django】当大型项目采用Django框架对于QueryDict以及模板的表单在Admin 管理工具的使用

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

作者头像
上进小菜猪
发布2022-12-13 18:29:42
1.7K0
发布2022-12-13 18:29:42
举报
文章被收录于专栏:我想境境的开发专栏

QueryDict

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

代码语言:javascript
复制
>>> 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请求:

代码语言:javascript
复制
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 对象

代码语言:javascript
复制
def runoob(request):
    return redirect("/index/")

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

Admin 管理工具

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

代码语言:javascript
复制
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数据模型,所以我们需要在注册时一起注册它们。显示效果如下:

代码语言:javascript
复制
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:

代码语言:javascript
复制
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的路径中找到基,注释掉两行代码(代码位于文件的开头):

代码语言:javascript
复制
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项目目录结构中。

代码语言:javascript
复制
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。

代码语言:javascript
复制
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>")
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-12-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • QueryDict
  • 表单
  • HttpRequest 对象
  • Admin 管理工具
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档