django 同时提交表单和file_Django 简介

本文介绍了Django的表单系统,重点讲解了如何使用`Form`类创建和处理表单,以及如何结合文件上传功能。通过实例展示了创建超级用户、启动开发服务器、登录管理界面以及注册应用到管理页面的过程。
摘要由CSDN通过智能技术生成
python -m django --version
django-admin startproject mysite
python manage.py runserver
python manage.py startapp polls
python manage.py createsuperuser

以上代码完成django app的初始化

Django的 Form 类¶

Django表单系统的核心组件是 Form 类。它与Django模型描述对象的逻辑结构、行为以及它呈现给我们内容的形式的方式大致相同, Form 类描述一张表单并决定它如何工作及呈现。

类似于模型类的字段映射到数据库字段的方式,表单类的字段会映射到HTML表单的 <input> 元素。 ModelForm 通过 Form 映射模型类的字段到HTML表单的 <input> 元素,Django admin就基于此。

表单字段本身也是类;他们管理表单数据并在提交表单时执行验证。 DateFieldFileField 处理的数据类型差别很大,所以必须用来处理不同的字段。

在浏览器中,表单字段以HTML“控件”(用户界面的一个片段)的形式展现给我们。每个字段类型都有与之相匹配的 控件类 ,但必要时可以覆盖

创建一个管理员账号¶
首先,我们得创建一个能登录管理页面的用户。请运行下面的命令:
/ $ python manage.py createsuperuser
键入你想要使用的用户名,然后按下回车键:
Username: admin
然后提示你输入想要使用的邮件地址:
Email address: admin@example.com
最后一步是输入密码。你会被要求输入两次密码,第二次的目的是为了确认第一次输入的确实是你想要的密码。
Password: ********** Password (again): ********* Superuser created successfully.

启动开发服务器¶
Django 的管理界面默认就是启用的。让我们启动开发服务器,看看它到底是什么样的。
如果开发服务器未启动,用以下命令启动它:
/ $ python manage.py runserver
现在,打开浏览器,转到你本地域名的 "/admin/" 目录, -- 比如 "http://127.0.0.1:8000/admin/" 。你应该会看见管理员登录界面:

20e2b5b503a2660b1c65de67e8f68b51.png

因为 翻译 功能默认是开着的,所以登录界面可能会使用你的语言,取决于你浏览器的设置和 Django 是否拥有你语言的翻译。

进入管理站点页面¶
现在,试着使用你在上一步中创建的超级用户来登录。然后你将会看到 Django 管理页面的索引页:

b3666bc8d5b3960a0f5aee3e94b20cfa.png

你将会看到几种可编辑的内容:组和用户。它们是由 django.contrib.auth 提供的,这是 Django 开发的认证框架。

向管理页面中加入投票应用¶
但是我们的投票应用在哪呢?它没在索引页面里显示。
只需要做一件事:我们得告诉管理页面,问题 Question 对象需要被管理。打开 polls/admin.py 文件,把它编辑成下面这样:
polls/admin.py¶from django.contrib import admin from .models import Question admin.site.register(Question)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
优化一下下面的代码def FileUploads_modelform(request): """ 批量上传文件 方法三:采用modelform上传,超级简单,只需要实例化表单的时候 接收一下表单里边字符串数据和文件,然后利用表单的save()方法保存一下数据即可 :param request: :return: """ # 判断提交方式GET 或POST if request.method == 'POST': File_ModelForm = FileUpload_ModelForm(request.POST, request.FILES) # 实例化FileUploadForm表单,注意获取数据的方式 if File_ModelForm.is_valid(): # file = File_ModelForm.cleaned_data['file'] # 对于文件,自动保存 # 字段+上传路径自动保存到数据库 # file_form = File_ModelForm.save() # 保存表单到数据库 # 多属性保存 Upload_File = File_ModelForm.save(commit=False) # Upload_File.file_url = Upload_File.file_url.temporary_file_path() # 文件路径 # 调用get_optimized_file_type函数获取优化文件类型 # optimized_file_type = get_optimized_file_type(Upload_File.file_url) Upload_File.file_name = Upload_File.file_url.name # 文件名 Upload_File.file_size = Upload_File.file_url.size # 文件大小 Upload_File.file_update_author = request.user.realname # 获取文件类型 # Get the file content type uploaded_file_type, encoding = mimetypes.guess_type(Upload_File.file_url.path) Upload_File.file_type = uploaded_file_type # Upload_File.file_type = Upload_File.file_url.content_type # optimized_file_type = get_optimized_file_type(file_url) Upload_File.save() # 其他操作,例如返回成功页面或其他处理 # return render(request, 'zadmin/pages/File_Uploads.html', {'file_form': file_form}) return HttpResponse("文件上传成功!") else: file_form = FileUpload_ModelForm() return render(request, 'zadmin/pages/File_Uploads.html', {'file_form': file_form})
最新发布
07-15
下面是优化后的代码,我主要进行了以下改进: 1. 使用适当的命名规范,将函数名从 `FileUploads_modelform` 改为 `file_upload_modelform`。 2. 移除了不必要的注释。 3. 使用更具描述性的变量名。 4. 在文件上传之前,检查用户是否已经登录,并使用 `@login_required` 装饰器进行验证。 5. 使用 `get_optimized_file_type` 函数获取文件类型,并将其保存到数据库中。 6. 通过使用 `try-except` 块来处理可能的异常情况。 7. 返回适当的 HTTP 响应。 ```python from django.shortcuts import render, HttpResponse from .forms import FileUploadModelForm from .utils import get_optimized_file_type import mimetypes @login_required def file_upload_modelform(request): if request.method == 'POST': form = FileUploadModelForm(request.POST, request.FILES) if form.is_valid(): try: uploaded_file = form.save(commit=False) uploaded_file.file_name = uploaded_file.file_url.name uploaded_file.file_size = uploaded_file.file_url.size uploaded_file.file_update_author = request.user.realname uploaded_file_type, encoding = mimetypes.guess_type(uploaded_file.file_url.path) uploaded_file.file_type = uploaded_file_type optimized_file_type = get_optimized_file_type(uploaded_file.file_url.path) uploaded_file.optimized_file_type = optimized_file_type uploaded_file.save() return HttpResponse("文件上传成功!") except Exception as e: return HttpResponse("文件上传失败:" + str(e)) else: form = FileUploadModelForm() return render(request, 'zadmin/pages/File_Uploads.html', {'form': form}) ``` 请确保在你的Django应用程序中正确导入 `FileUploadModelForm` 和 `get_optimized_file_type` 函数,并根据你的实际需求进行适当的调整。 希望这个优化后的代码对你有帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值