0

私はジャンゴで奇妙な問題に直面しています。フォームセットで is_valid() を実行すると、各サブフォームの 1 つの値が None に設定されているようです。これを確認するために、cleaned_data dict を出力する 2 つのデバッグ行を追加しました。1 つはcleaned_qty() の最後にあり、もう 1 つは is_valid() の直後にあります。

フォームは次のとおりです。

class ProductsForm(forms.Form):
    product_ref     = forms.CharField(max_length=6, widget=forms.HiddenInput)
    product_name    = forms.CharField(max_length=200, widget=forms.HiddenInput)
    unit            = forms.CharField(max_length=16, widget=forms.HiddenInput)
    qty             = forms.DecimalField(max_digits=6, decimal_places=3,
                        widget=forms.TextInput(attrs={'size': 5}))

    def clean_qty(self):
        data = self.cleaned_data

        if data['qty'] < 0:
            raise ValidationError('La quantité doit être positive')

        unit = Unit.objects.get(pk=data['unit'])

        if not unit.accept_dec and '.' in str(data['qty']) \
        and int(str(data['qty']).split('.')[1]) != 0:
            raise ValidationError('La quantité doit être entière')

        print "!!!" + str(data) + "!!!"

ProductsFormSet = formsets.formset_factory(ProductsForm, extra=0,
    can_delete=True)

そして、これがビューの始まりです:

def cart(request):
    if request.method == 'POST':
        products_formset = ProductsFormSet(request.POST, prefix='products')
        cart_form = CartForm(request.POST, prefix='cart')
        if products_formset.is_valid() and cart_form.is_valid():
            '''
                Create and save the cart
                Send a confirmation email
            '''

            for form in products_formset:
                print "???" + str(form.cleaned_data) + "???"

そして、フォームを送信したときの結果:

DEBUG:django.db.backends:(0.000) SELECT `catalog_unit`.`value`, `catalog_unit`.`plural_val`, `catalog_unit`.`accept_dec` FROM `catalog_unit` WHERE `catalog_unit`.`value` = 'Truc' ; args=(u'Truc',)
!!!{'product_ref': u'BDL233', 'product_name': u'Bidule', 'unit': u'Truc', 'qty': Decimal('2.2')}!!!
DEBUG:django.db.backends:(0.001) SELECT `catalog_unit`.`value`, `catalog_unit`.`plural_val`, `catalog_unit`.`accept_dec` FROM `catalog_unit` WHERE `catalog_unit`.`value` = 'Truc' ; args=(u'Truc',)
!!!{'product_ref': u'MCH024', 'product_name': u'Machin', 'unit': u'Truc', 'qty': Decimal('1.3')}!!!
DEBUG:django.db.backends:(0.000) SELECT `catalog_unit`.`value`, `catalog_unit`.`plural_val`, `catalog_unit`.`accept_dec` FROM `catalog_unit` WHERE `catalog_unit`.`value` = 'Chacal' ; args=(u'Chacal',)
!!!{'product_ref': u'CHO127', 'product_name': u'Chouette', 'unit': u'Chacal', 'qty': Decimal('3')}!!!
???{'DELETE': False, 'product_ref': u'BDL233', 'product_name': u'Bidule', 'unit': u'Truc', 'qty': None}???
???{'DELETE': False, 'product_ref': u'MCH024', 'product_name': u'Machin', 'unit': u'Truc', 'qty': None}???
???{'DELETE': False, 'product_ref': u'CHO127', 'product_name': u'Chouette', 'unit': u'Chacal', 'qty': None}???

ご覧のとおり、唯一の違いは qty が None に設定されていることです。

この振る舞いがどこから来るのか、私にはわかりません。

光さん、これからよろしくお願いします。

4

1 に答える 1

2

すべてのclean_FIELDメソッドは、検証される値を返す必要があります。したがって、clean_qtyメソッドにはが必要return data['qty']です。

于 2012-07-31T08:27:04.343 に答える