Ah I see. Thanks for the explanation!
On Dec 18, 9:38 am, "alex.gay...@gmail.com" <alex.gay...@gmail.com>
wrote:
> The reason this occurs, even with valid data, is because is_valid()
> triggers the validation procedures which set the cleaned_data
> attribute.
>
> Alex
>
> On Dec 18, 2:33 am, marty3d <martin.kjellb...@gmail.com> wrote:
>
> > Thanks for the English lesson! :)
>
> > As you both pointed out, the .is_valid() should be used here. I
> > skipped that part because the data was indeed valid and still got the
> > error message. It has been tried, sorry for not mentioning that.
> > But actually, by trying it again, with the Werkzeug debugger turned
> > off (which generated the traceback in the first place) AND
> > using .is_valid(), it worked! (and now, with Werkzeug turned back on
> > as well)
>
> > I guess I've been at it so long my head has taken an extra spin :)
>
> > Thanks again and sorry for bothering you with my own *bleep*-ups!
> > /Martin
>
> > On Dec 17, 4:23 pm, "Karen Tracey" <kmtra...@gmail.com> wrote:
>
> > > On Wed, Dec 17, 2008 at 7:49 AM, marty3d <martin.kjellb...@gmail.com>
> > > wrote:
>
> > > > Hi!
>
> > > > I've been stuck with this for some days now, and can't find any
> > > > answers whatsoever. Please bare with me since I'm a newbie with Python/
> > > > Django.
>
> > > (English nitpick: the word is bear, not bare, that you're looking for in
> > > that idiom.)
>
> > > > I have this form that's created and populated using
> > > > 'modelformset_factory'. What it's supposed to do is to
> > > > 1. show a number of sets so the user can add several at one time. Also
> > > > show the added ones, with the possibility to delete them if necessary.
> > > > 2. Save content. This means insert/update/delete.
>
> > > You've left out a step here. Before you can save content you need to
> > > verify
> > > that the data submitted by the user is valid. You seem to have jumped
> > > into
> > > an advanced usage of forms without covering the basics:
>
> > >http://docs.djangoproject.com/en/dev/topics/forms/#using-a-form-in-a-...
>
> > > Calling form.is_valid() and verifying that it returns True is essential
> > > before attempting to do anything (other than re-displaying it with the
> > > error
> > > annotations) with the form created from POST data. You cannot save a form
> > > that is not valid.
>
> > > > Easy enough, ey? But I'm stuck at the error "AttributeError:
> > > > 'OptionForm' object has no attribute 'cleaned_data'". Strange things
> > > > happen here. "OptionForm" doesn't exist for example. I guess Django
> > > > adds "Form" by itself, why I don't know.
>
> > > cleaned_data only exists for valid forms. Any error like "whateverform
> > > has
> > > no attribute cleaned_data" means your code is proceeding under the
> > > assumption that the form has validated when in fact it has not.
>
> > > As for OptionForm, your code requests creation of a model formset from
> > > your
> > > Option model. To do this, Django dynamically creates a ModelForm class
> > > and
> > > names it <your-model-name>Form. Each individual form in your formset is
> > > an
> > > OptionForm.
>
> > > > The full traceback:
> > > > Traceback (most recent call last):
> > > > File "C:\Program Files\Python25\Lib\site-packages\django\core\servers
> > > > \basehttp.py", line 635, in __call__
> > > > return self.application(environ, start_response)
> > > > File "C:\Program Files\Python25\Lib\site-packages\django\core
> > > > \handlers\wsgi.py", line 239, in __call__
> > > > response = self.get_response(request)
> > > > File "C:\Program Files\Python25\Lib\site-packages\django\core
> > > > \handlers\base.py", line 128, in get_response
> > > > return self.handle_uncaught_exception(request, resolver, exc_info)
> > > > File "C:\Program Files\Python25\Lib\site-packages\django\core
> > > > \handlers\base.py", line 148, in handle_uncaught_exception
> > > > return debug.technical_500_response(request, *exc_info)
> > > > File "C:\Program Files\Python25\Lib\site-packages\django\core
> > > > \handlers\base.py", line 86, in get_response
> > > > response = callback(request, *callback_args, **callback_kwargs)
> > > > File "C:\Projects\dis_dk\invites_project\invites\views.py", line
> > > > 242, in OptionEdit
> > > > formset.save()
> > > > File "C:\Program Files\Python25\Lib\site-packages\django\forms
> > > > \models.py", line 389, in save
> > > > return self.save_existing_objects(commit) + self.save_new_objects
> > > > (commit)
> > > > File "C:\Program Files\Python25\Lib\site-packages\django\forms
> > > > \models.py", line 403, in save_existing_objects
> > > > obj = existing_objects[form.cleaned_data[self._pk_field.name]]
> > > > AttributeError: 'OptionForm' object has no attribute 'cleaned_data'
>
> > > This traceback confuses me. It shows that in attempting to get the
> > > response
> > > [get_response(request)], an uncaught exception was raised
> > > [handle_uncaught_exception(request, ...), so it proceeds to begin to
> > > return
> > > a debug page [return debug.technical_500_response(request, ...)] but then
> > > we
> > > jump into code that is not part of the default
> > > debug.technical_500_response
> > > and that code looks like it tries calling your view code again, generating
> > > (probably) the same exception as what caused the call to
> > > "hanlde_uncaught_exception" in the first place. Have you done something
> > > to
> > > modify the default technical_500_response?
>
> > > > Code:
> > > > models.py:
> > > > ---------
> > > > class Option(models.Model):
> > > > option_name = models.CharField(max_length=200)
> > > > option_value = models.CharField(max_length=200)
> > > > default_selected = models.BooleanField(default=False)
> > > > def __unicode__(self):
> > > > return self.option_name
>
> > > > views.py:
> > > > --------
> > > > from models import Option
>
> > > > def OptionEdit(request, invite_id=None, form_id=None, field_id=None):
> > > > from django.forms.models import modelformset_factory
> > > > instance = Option.objects.all()
> > > > if request.method == 'POST':
> > > > OptionFormSet = modelformset_factory(Option)
> > > > formset = OptionFormSet(request.POST, request.FILES,
> > > > queryset=instance)
> > > > formset.save()
>
> > > Here you are calling formset.save() without verifying formset.is_valid()
> > > is
> > > True. That's what's leading to the exception. But I find the code path
> > > shown in the traceback confusing and troublesome as well, and I can't
> > > explain that one uless you've done something to attempt to customize how
> > > Django handles 500 server errors.
>
> > > 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
-~----------~----~----~----~------~----~------~--~---