Karen, you're recommendations were great. After fixing the model form
problem, I found that I and others had problems with PILL. Apparently, it's
not easy to install correctly on Ubuntu, and if it isn't you may get
ImageField validation errors when saving images. Here's a link that might
help fix the problem for others who may run into it:

http://www.answermysearches.com/fixing-pil-ioerror-decoder-jpeg-not-available/320/

Thanks again for taking the time to respond.


On Thu, Aug 6, 2009 at 5:02 PM, Malcolm MacKinnon <mmack3...@gmail.com>wrote:

> Thanks, Karen. I really appreciate all the time you put in looking at this
> and your comments are very informative. You were right about naming the
> primary key PK (I thought Django would like that, but it doesn't). I changed
> it to PRIM and the model form renders the way it should in photos.html. I
> did run into one more problem: when I try to save a jpeg image, I get a
> ValueError exception:
>
> The Images could not be created because the data didn't validate.
>
> I know the file is a jpeg file. Here is my new form and view:
>
> class PictureForm(ModelForm):
>    class Meta:
>        model=Images
>        exclude = ('prim',)
>
> def image_loads(request):
>     form=PictureForm()
>     if request.method=='POST':
>         form=PictureForm(request.POST,  request.FILES)
>         if form.is_multipart:
>             form.save(commit=False)
>             form.save()
>             form=PictureForm()
>             return render_to_response('photos.html', {'form':form,  },
> context_instance = RequestContext(request))
>
>
>
>
>     return render_to_response('photos.html', {'form':form,  },
> context_instance = RequestContext(request))
> Here is the error:
> Environment:
>
> Request Method: POST
> Request URL: http://localhost:8000/photos/
> Django Version: 1.1 beta 1 SVN-10891
> Python Version: 2.5.2
> Installed Applications:
> ['django.contrib.auth',
>  'django.contrib.contenttypes',
>  'django.contrib.sessions',
>  'django.contrib.sites',
>  'django.contrib.admin',
>  'orders1.onhand',
>  'registration']
> Installed Middleware:
> ('django.middleware.common.CommonMiddleware',
>  'django.contrib.csrf.middleware.CsrfMiddleware',
>  'django.contrib.sessions.middleware.SessionMiddleware',
>  'django.contrib.auth.middleware.AuthenticationMiddleware')
>
>
> Traceback:
> File "/usr/lib/python2.5/site-packages/django/core/handlers/base.py" in
> get_response
>   92.                 response = callback(request, *callback_args,
> **callback_kwargs)
> File "/home/malcolm/data1/orders1/../orders1/onhand/views.py" in
> image_loads
>   49.             form.save(commit=False)
> File "/usr/lib/python2.5/site-packages/django/forms/models.py" in save
>   407.                              fail_message, commit,
> exclude=self._meta.exclude)
> File "/usr/lib/python2.5/site-packages/django/forms/models.py" in
> save_instance
>   42.                          " validate." % (opts.object_name,
> fail_message))
>
> Exception Type: ValueError at /photos/
> Exception Value: The Images could not be created because the data didn't
> validate.
>
> I get the same error when I include the field PRIM. Again, thanks for your
> time. I've put in hours trying to figure this out, and your comments were
> great.
>
>
> On Thu, Aug 6, 2009 at 3:32 PM, Karen Tracey <kmtra...@gmail.com> wrote:
>
>>
>> On Aug 6, 1:56 am, Mac <mmack3...@gmail.com> wrote:
>> > Hi,
>> >
>> > I'm new to django. When I try to upload image files, I get runtime
>> > errors. Here's my model:
>> > models.py
>> >
>> > class Images(models.Model):
>> >     pk = models.IntegerField(primary_key=True, db_column='PK') # Field
>> > name made lowercase.
>>
>> Unless you are going to be manually assigning values here -- and I
>> don't see any evidence of that in your code -- you probably want this
>> to be an AutoField, not an IntegerField.  Based on the comments in
>> this model I'm guessing that it was auto-generated by inspectdb.  Note
>> the results of inspectdb are meant to serve as a starting point for
>> your models, and in most cases will require some tweaking, such as
>> changing this generated IntegerField to an AutoField, assuming you
>> want this to be the automatically-assigned primary key field for the
>> model.
>>
>> There's also another problem with this field but we'll get to that
>> later.
>>
>> >     photos = models.ImageField(db_column='PHOTOS', upload_to='img',
>> > blank=True) # Field name made lowercase.
>> >     items = models.CharField(max_length=255, db_column='ITEMS',
>> > blank=True) # Field name made lowercase.
>> >     date = models.DateField(null=True, db_column='DATE', blank=True) #
>> > Field name made lowercase.
>> >     class Meta:
>> >         db_table = u'IMAGES'
>> >
>> > Here's my view:
>> > rom django.core.files.uploadedfile import SimpleUploadedFile
>> > from PIL import Image
>> > Image.init()
>> > class PictureForm(forms.Form):
>> >    pic=forms.ImageField()
>> >    def create(self, file):
>> >         mymodel = Images()
>> >         mymodel.save_image_file(file.name, file, save=True)
>> >         return mymodel
>> >
>>
>> This looks very odd.  If you want a form to allow you to upload an
>> image and save an Images model instances, why not use a ModelForm?
>>
>> > def image_loads(request):
>> >     form=PictureForm()
>> >     if request.method=='POST':
>> >         form=PictureForm(request.POST,  request.FILES)
>> >         if form.is_valid:
>>
>> This line will always evaluate to True, regardless of whether or not
>> the form would pass validation.  is_valid is a method, so you need to
>> call it:
>>
>> if form.is_valid():
>>
>> They way you have written it you are simply checking to see if the
>> form has the attribute is_valid, which it always will.
>>
>>
>> >             form.create(request.FILES)
>>
>> Note that request.FILES is a dictionary-like object.  However your
>> create method above seems to be expecting an individual file.  I think
>> you'd see a problem here if you ever got far enough for create to try
>> to access its file parameter.
>>
>> >
>> >     return render_to_response('photos.html', {'form':form,  },
>> > context_instance = RequestContext(request))
>> >
>> > Here's my photos.html template:
>> >
>> [snip] because I don't notice any problem there.
>> >
>> > Any ideas why? I also tried creating a ModelForm using Images as the
>> > model, and I got the same runtime error. Here's the details:
>> >
>>
>> Oh, you have tried a ModelForm.  That is the right approach, go back
>> to it. The problem you are seeing is in no way related to using a
>> ModelForm and moving away from the right approach didn't get you any
>> closer to solving the real problem.
>>
>> > Environment:
>> >
>> > Request Method: POST
>> > Request URL:http://localhost:8000/photos/
>> > Django Version: 1.1 beta 1 SVN-10891
>> > Python Version: 2.5.2
>> > Installed Applications:
>> > ['django.contrib.auth',
>> >  'django.contrib.contenttypes',
>> >  'django.contrib.sessions',
>> >  'django.contrib.sites',
>> >  'django.contrib.admin',
>> >  'orders1.onhand',
>> >  'registration']
>> > Installed Middleware:
>> > ('django.middleware.common.CommonMiddleware',
>> >  'django.contrib.csrf.middleware.CsrfMiddleware',
>> >  'django.contrib.sessions.middleware.SessionMiddleware',
>> >  'django.contrib.auth.middleware.AuthenticationMiddleware')
>> >
>> > Traceback:
>> > File "/usr/lib/python2.5/site-packages/django/core/handlers/base.py"
>> > in get_response
>> >   92.                 response = callback(request, *callback_args,
>> > **callback_kwargs)
>> > File "/home/malcolm/data1/orders1/../orders1/onhand/views.py" in
>> > image_loads
>> >   50.             form.create(request.FILES)
>> > File "/home/malcolm/data1/orders1/../orders1/onhand/views.py" in
>> > create
>> >   41.         mymodel = Images()
>> > File "/usr/lib/python2.5/site-packages/django/db/models/base.py" in
>> > __init__
>>
>> Note how far you have gotten into your code.  This problem has nothing
>> to do with uploading files: you are running into trouble simply trying
>> to create an Images instance.  I suggest you take some time to do some
>> basic verification that things like your model definitions are working
>> before jumping into creating views and forms and templates, etc.
>> Playing around in the Python shell with your models, making sure you
>> can properly access existing ones and create new ones, is really
>> something that should be done before you start writing a lot of other
>> code.  It is very worthwhile and makes everything go smoother if you
>> make sure that piece A works before building B,C, and D which all
>> depend on A.
>>
>> >   313.                 setattr(self, field.attname, val)
>> > File "/usr/lib/python2.5/site-packages/django/db/models/base.py" in
>> > _set_pk_val
>> >   377.         return setattr(self, self._meta.pk.attname, value)
>> > File "/usr/lib/python2.5/site-packages/django/db/models/base.py" in
>> > _set_pk_val
>> >   377.         return setattr(self, self._meta.pk.attname, value)
>> > File "/usr/lib/python2.5/site-packages/django/db/models/base.py" in
>> > _set_pk_val
>>
>> OK, we did not need to see 982 repetitions of line 377 in django/db/
>> models/base.py.  Google doesn't think so either and makes it hard to
>> see the end of the message.  You could have snipped at least 975 of
>> the copies and we would have gotten the idea that there's a problem
>> with infinite recursion here, ultimately reported as:
>>
>> Exception Type: RuntimeError at /photos/
>> Exception Value: maximum recursion depth exceeded
>>
>> by following the 'read more' link.
>>
>> This looks like a Django bug or two.  The problem is your primary key
>> field is named 'pk', which is the shortcut name that you can use to
>> refer to a primary key field without knowing its actual name.  I don't
>> think it is feasible to allow a field to actually be named 'pk': if
>> you name a field 'pk' and it's not the primary key field, which field
>> should be returned when you try to access model.pk -- the field you
>> named 'pk' or the primary key field?  So probably Django should report
>> this as an error on syncdb and make you change it.  Also, inspectdb
>> ought not create a field with that name -- it already has logic to fix
>> up some other potentially problematic names so it should do the same
>> for 'pk', I expect.
>>
>> The way to fix this in your code is to simply rename that field to
>> something else.
>>
>> Karen
>> >>
>>
>

--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to 
django-users+unsubscr...@googlegroups.com
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to