Found out what was causing the error but not why... It seems that when I tell my model to not exclude the "pet" field, that everything works fine. (ie, I select a pet from the dropdown) When I add it to the exclude list and try to set it manually I get an error.
What seems to work is allowing the pet selection but then setting it after I do save(commit=False). I'm trying to set it up as a hidden field but I keep getting that it's a required field. I can't seem to figure out how to set a default value. Any ideas why this might be happening? -Chris On Sep 2, 9:52 am, TiNo <[EMAIL PROTECTED]> wrote: > You could check with the pdb debugger where the error is returned, and maybe > you can also see what field is causing the problem. > > On Tue, Sep 2, 2008 at 3:34 PM, flynnguy <[EMAIL PROTECTED]> wrote: > > > Thanks for the tips, I did know about the get_object_or_404 and had > > that there originally but I wanted to rule things out and was hoping > > if the pet_id didn't exist, that would throw an error I'm used to > > seeing. Unfortunately that seems to not be the problem. I did make the > > changes regarding the Media.views field but that didn't seem to make > > any difference but does clean the code up a bit. Thanks for your help. > > > From the error it looks like a related field doesn't exist but I can't > > tell what field it's complaining about. Usually the error messages are > > helpful, this time, not so much. > > -Chris > > > On Aug 31, 12:37 pm, TiNo <[EMAIL PROTECTED]> wrote: > > > On Fri, Aug 29, 2008 at 6:37 PM, flynnguy <[EMAIL PROTECTED]> wrote: > > > > .. > > > > However there are certain fields I want to set manually so I tried > > > > this: > > > > class AddPhotoForm(ModelForm): > > > > class Meta: > > > > model = Media > > > > exclude = ('type', 'pet', 'views') > > > > > def add_pet_photo(request, pet_id): > > > > pet = Pet.objects.get(id=pet_id) > > > > It is possible a pet with this id does not exist, so use > > get_object_or_404, > > > or catch the DoesNotExist here and raise a 404. > > > > > if request.method == 'POST': > > > > form = AddPhotoForm(data=request.POST, files=request.FILES) > > > > if form.is_valid(): > > > > added_photo = form.save(commit=False) > > > > added_photo.pet = pet > > > > added_photo.type = 'P' > > > > added_photo.views = 0 # this is a zero and is used as a > > > > counter > > > > If you add 'blank=True' to 'views = models.IntegerField(default=0)' in > > your > > > model, you don't need to add the last line. You also don't need the > > > 'self.views = 0' in the save method below: > > > > > def save(self): > > > > if not self.id: > > > > self.created = datetime.datetime.today() > > > > self.views = 0 > > > > self.updated = datetime.datetime.today() > > > > self.thumbnail = create_thumbnail(self.image, THUMB_WIDTH, > > > > THUMB_HEIGHT) > > > > super(Media, self).save() > > > > Don't think it will solve your problem, some tips though. > > > > TiNo --~--~---------~--~----~------------~-------~--~----~ 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 [EMAIL PROTECTED] For more options, visit this group at http://groups.google.com/group/django-users?hl=en -~----------~----~----~----~------~----~------~--~---