English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
Webアプリケーションでは、画像や音楽、PDF形式、テキストなどのファイルをアップロードできるようにすることが非常に便利です。このセクションでは、Djangoを使用してファイルをアップロードする方法について説明します。
画像アップロードの開発を始める前に、Pythonの画像ライブラリ(PIL)がインストールされていることを確認してください。ここでは画像のアップロードについて説明します。まず、myappに設定ファイルの形式を作成しましょう。/forms.py -
urls.py サンプル 202# Filename : example.py3# Copyright : 0 By oldtoolbag.com codebox 2020-08-08 #-*- coding: utf-8 -*- from django import forms class ProfileForm(forms.Form): name = forms.CharField(max_length= 100) picture = forms.ImageFields()
正如你所看到的,这里的主要区别仅仅是 forms.ImageField。ImageField字段将确保上传的文件是一个图像。如果不是,格式验证将失败。
现在,让我们创建一个 "Profile" 模型,以保存上传的资料。在 myapp/models.py -
urls.py サンプル 202# Filename : example.py3# Copyright : 0 By oldtoolbag.com codebox 2020-08-08 from django.db import models class Profile(models.Model): name = models.CharField(max_length= 50) picture = models.ImageField(upload_to='pictures') class Meta: db_table = "profile"
正如所看到的模型,ImageField 使用强制性参数:upload_to. 这表示硬盘驱动器,图像保存所在的地方。注意,该参数将被添加到 settings.py文件中定义的MEDIA_ROOT选项。
现在我们有表单和模型,让我们来创建视图,在 myapp/ views.py -
urls.py サンプル 202# Filename : example.py3# Copyright : 0 By oldtoolbag.com codebox 2020-08-08 #-*- coding: utf-8 -*- from myapp.forms import ProfileForm from myapp.models import Profile def SaveProfile(request): saved = False if request.method == "POST": #Get the posted form MyProfileForm = ProfileForm(request.POST, request.FILES) if MyProfileForm.is_valid(): profile = Profile() profile.name = MyProfileForm.cleaned_data["name"]
myapp//
urls.py サンプル 202# Filename : example.py3# Copyright : 0 By oldtoolbag.com codebox 2020-08-08 / / form>/div> form>/body>
myapp//
urls.py サンプル 202# Filename : example.py3# Copyright : 0 By oldtoolbag.com codebox 2020-08-08 /- action="{% url "myapp.views.SaveProfile" %}" method="POST" <div style="max-width:470px;"> <center> <input type="text" style="margin-left:20%;" placeholder="Name" name="name" /> form>/strong> form>/button> <br> <div style="max-width:470px;"> <center> <input type="file" style="margin-left:20%;" placeholder="Picture" name="picture" /> form>/strong> form>/button> <br> <div style="max-width:470px;"> <center> <button style="border:0px;background-color:#4285F4;margin-top:8%; height:35px;width:80%;margin-left:19%;type="submit" value="Login" / form>/<strong>Login< form>/strong> form>/button> form>/center> form>/div> form>/body>
</html>
urls.py サンプル 202# Filename : example.py3# Copyright : 0 By oldtoolbag.com codebox 2020-08-08 # Author by : www.w # Date : from django.conf.urls import patterns, url urlpatterns = patterns(/', TemplateView.as_view( template_name = 'profile.htmll')), url(r'^saved',/', 'SaveProfile', name = 'saved') )
アクセスする際に「/myapp/「profile」,次のように profile.htmll テンプレートが表示されます −
形式が提出された後、保存されたテンプレートは以下のように表示されます −
ここでは画像アップロードの例を説明しますが、他のタイプのファイルをアップロードする場合は、これらのモデル及び FileField フォームの ImageField を変更してください。