Django 上传图片(整理)

Django 上传图片(整理)
找到两篇相关帖子,mark一下:
一。
首先在model上要有一个ImageFiled字段,
同时 模板上对应放一个<input type="file" name = "file">,
以下就是视图的代码了,
import Image
import StringIO
from datetime import datetime
def add_topic(request):
       file_obj = request.FILES.get('file', None)   
       if file_obj:
             data = file_obj['content']
             f = StringIO.StringIO(data)
             image = Image.open(f)
             image = image.convert('RGB')
             abs_name = '%s_%s_%s' %(str(request.user),"
                    str(datetime.today()).replace(':', '-')[:-7],"
                    file_obj['filename'])
              image.save(file(abs_name, 'wb'))
        return HttpResponseRedirect("/forum/forum/")

二。

谈谈django中图片上传的2种处理方式

关键字: django 上传图片 pil

    首先申明该文使用的django 版本为svn 版本,我每天都在更新 ,python 是2.5,pil 也是最新的版本。

    通常情况下用django上传图片我们会定义一个django.forms.Form的子类,比如:

Python代码
  1. # coding: utf-8  
  2.   
  3. import django.forms as forms  
  4.   
  5. class PictureForm(forms.Form):   
  6.     # ......     
  7.     # 图片  
  8.     imagefile = forms.ImageField()  
  9.     # ......  
# coding: utf-8
import django.forms as forms
class PictureForm(forms.Form):
# ......
# 图片
imagefile = forms.ImageField()
# ......

     然后我们在服务端会定义一个函数来处理图片上传,我们先来看看一般的做法:

Python代码
  1. # coding: utf-8  
  2.   
  3. from django.http import HttpResponse  
  4.   
  5. def addPicture(request):  
  6.     if request.method == 'POST':  
  7.         form = PictureForm(request.POST, request.FILES)  
  8.         if form.is_valid():  
  9.             f = request.FILES["imagefile"]  
  10.             # des_origin_path 为你在服务器上保存原始图片的文件物理路径  
  11.             des_origin_f = open(des_origin_path, "ab")  
  12.             for chunk in f.chunks():  
  13.                 des_origin_f.write(chunk)  
  14.             des_origin_f.close()  
  15.               
  16.             # 图片文件被保存在硬盘上后,你可以用pil的Image.open打开进行处理,比如改变大小,加水印等等  
# coding: utf-8
from django.http import HttpResponse
def addPicture(request):
if request.method == 'POST':
form = PictureForm(request.POST, request.FILES)
if form.is_valid():
f = request.FILES["imagefile"]
# des_origin_path 为你在服务器上保存原始图片的文件物理路径
des_origin_f = open(des_origin_path, "ab")
for chunk in f.chunks():
des_origin_f.write(chunk)
des_origin_f.close()
# 图片文件被保存在硬盘上后,你可以用pil的Image.open打开进行处理,比如改变大小,加水印等等

     在上面这种传统的做法中,是把图片文件保存到硬盘上后,再由pil图形库从硬盘上加载,再进行图片处理,明显多了很多的硬盘IO操作,如果你是一个图片处理量很大的应用,显然不想看到这样的局面。那我们来看看另外一个做法:

Python代码
  1. # coding: utf-8  
  2.   
  3. from django.http import HttpResponse  
  4. import ImageFile  
  5.   
  6. def addPicture(request):  
  7.     if request.method == 'POST':  
  8.         form = PictureForm(request.POST, request.FILES)  
  9.         if form.is_valid():  
  10.             f = request.FILES["imagefile"]  
  11.             parser = ImageFile.Parser()  
  12.             for chunk in f.chunks():  
  13.                 parser.feed(chunk)  
  14.             img = parser.close()  
  15.             # 在img被保存之前,可以进行图片的各种操作,在各种操作完成后,在进行一次写操作  
  16.             img.save("yoursavepath")  
# coding: utf-8
from django.http import HttpResponse
import ImageFile
def addPicture(request):
if request.method == 'POST':
form = PictureForm(request.POST, request.FILES)
if form.is_valid():
f = request.FILES["imagefile"]
parser = ImageFile.Parser()
for chunk in f.chunks():
parser.feed(chunk)
img = parser.close()
# 在img被保存之前,可以进行图片的各种操作,在各种操作完成后,在进行一次写操作
img.save("yoursavepath")

     在上面的做法中,我们利用pil的ImageFile直接从django接收的数据流中构建出图形对象,进行处理后,在保存,减少了硬盘的读操作。现在网 上有些例子使用StringIO对象来作为pil Image.open的输入,经过我多次尝试,在ubuntu以及winxp、centos上都要报异常,我想可能跟pil的版本有关,或许以前的低版本 pil的确可以处理。



你可能感兴趣的:(Django 上传图片(整理))