找到两篇相关帖子,mark一下:
一。
首先在model上要有一个ImageFiled字段,
同时 模板上对应放一个,
以下就是视图的代码了,
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 上传图片 pil
首先申明该文使用的
版本为
版本,我每天都在更新
,
是2.5,
也是最新的版本。
通常情况下用django上传图片我们会定义一个django.forms.Form的子类,比如:
Python代码
- # coding: utf-8
-
- import django.forms as forms
-
- class PictureForm(forms.Form):
- # ......
- # 图片
- imagefile = forms.ImageField()
- # ......
# coding: utf-8
import django.forms as forms
class PictureForm(forms.Form):
# ......
# 图片
imagefile = forms.ImageField()
# ......
然后我们在服务端会定义一个函数来处理图片上传,我们先来看看一般的做法:
Python代码
- # 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打开进行处理,比如改变大小,加水印等等
# 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代码
- # 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")
# 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的确可以处理。
阅读(473) | 评论(0) | 转发(0) |