English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Django ファイルのアップロード

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 を変更してください。