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 -~----------~----~----~----~------~----~------~--~---