Django AttributeError: 表单对象没有属性'_errors'

8

我正在重写表单中的init方法,但是现在出现了错误'TransactionForm' object has no attribute '_errors'

我希望这个方法能正常工作,因为我在我的init中包含了super,但可能是我不理解如何正确使用它。希望您能给我一个解释。我需要做什么才能让form.errors正常工作呢?

完整的回溯信息:

Traceback: 文件"C:\Program Files\Python36\lib\site-packages\django\core\handlers\exception.py"中的inner函数 第35行。 response = get_response(request) 文件"C:\Program Files\Python36\lib\site-packages\django\core\handlers\base.py"中的_get_response函数 第128行。 response = self.process_exception_by_middleware(e, request) 文件"C:\Program Files\Python36\lib\site-packages\django\core\handlers\base.py"中的_get_response函数 第126行。 response = wrapped_callback(request, *callback_args, **callback_kwargs) 文件"C:\py\portfolio-project\myportfolio\views.py"中的add_transaction函数 第136行。 return render(request, 'myportfolio/add_transaction.html', {'form': form}) 文件"C:\Program Files\Python36\lib\site-packages\django\shortcuts.py"中的render函数 第36行。 content = loader.render_to_string(template_name, context, request, using=using) 文件"C:\Program Files\Python36\lib\site-packages\django\template\loader.py"中的render_to_string函数 第62行。 return template.render(context, request) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render函数 第175行。 return self._render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的_render函数 第167行。 return self.nodelist.render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render函数 第943行。 bit = node.render_annotated(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render_annotated函数 第910行。 return self.render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\loader_tags.py"中的render函数 第155行。 return compiled_parent._render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的_render函数 第167行。 return self.nodelist.render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render函数 第943行。 bit = node.render_annotated(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render_annotated函数 第910行。 return self.render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\loader_tags.py"中的render函数 第155行。 return compiled_parent._render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的_render函数 第167行。 return self.nodelist.render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render函数 第943行。 bit = node.render_annotated(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render_annotated函数 第910行。 return self.render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\loader_tags.py"中的render函数 第67行。 result = block.nodelist.render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render函数 第943行。 bit = node.render_annotated(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render_annotated函数 第910行。 return self.render(context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render函数 第999行。 return render_value_in_context(output, context) 文件"C:\Program Files\Python36\lib\site-packages\django\template\base.py"中的render_value_in_context函数 第978行。 value = str(value) 文件"C:\Program Files\Python36\lib\site-packages\django\utils\html.py"中的 第371行。 klass.str = lambda self: mark_safe(klass_str(self)) 文件"C:\Program Files\Python36\lib\site-packages\django\forms\forms.py"中的str函数 第136行。 return self.as_table() 文件"C:\Program Files\Python36\lib\site-packages\django\forms\forms.py"中的as_table函数 第279行。 errors_on_separate_row=False) 文件"C

表单

class TransactionForm(forms.ModelForm):     
    CHOICES = ((1, 'Buy'), (2, 'Sell'),)

    coin = forms.ModelChoiceField(queryset = Coin.objects.all()) 
    buysell = forms.ChoiceField(choices = CHOICES)

    field_order = ['buysell', 'coin', 'amount', 'trade_price']

    class Meta:
        model = Transactions
        fields = {'buysell', 'coin', 'amount', 'trade_price'}

    def __init__(self, coin_price = None, user = None, *args, **kwargs):

        if user:
            self.user = user
            qs_coin = Portfolio.objects.filter(user = self.user).values('coin').distinct()
            super(TransactionForm, self).__init__(self.user, *args, **kwargs)
            self.fields['coin'].queryset = qs_coin

        if coin_price:
            self.coin_price = coin_price
            super(TransactionForm, self).__init__(self.user, self.coin_price, *args, **kwargs)
            self.fields['price'] = self.coin_price

视图

def add_transaction(request):
    print(request.method)
    print("test1")

    print(request.GET)

    if request.method == "GET":
        if request.is_ajax():
            print("ajax test")

            data = {
                'test': "test1"
            }

            form = TransactionForm(request.GET, user = request.user, coin_price = GetCoin("Bitcoin").price)

            return JsonResponse(data)


    form = TransactionForm()
    if request.method == "POST":
        print("test2")
        form = TransactionForm(request.POST)
        if form.is_valid():
            print("test3")
            obj = form.save(commit = False)
            obj.user = request.user
            obj.save()
            return HttpResponseRedirect('/myportfolio/')
        else: 
            print(form.errors)

    return render(request, 'myportfolio/add_transaction.html', {'form': form})
2个回答

13

如果未提供coin_priceuser,则不会调用表单的超类__init__方法。这就是为什么表单属性如_errors没有被创建的原因。您需要像这样重写表单的__init__

def __init__(self, coin_price = None, user = None, *args, **kwargs):
        super(TransactionForm, self).__init__(*args, **kwargs)
        if user:
            self.user = user
            qs_coin = Portfolio.objects.filter(user = self.user).values('coin').distinct()
            self.fields['coin'].queryset = qs_coin

        if coin_price:
            self.coin_price = coin_price
            self.fields['price'] = self.coin_price
为了确保在任何情况下都调用super.__init__()

0

我刚刚遇到了一个 bug,请注意在快速编码时,由于命名相似性,您的调试器自动填充可能会提供视图而不是表单。

因此,请确保您实际上正在调用表单而不是视图!!!我花了半个小时才弄清楚...


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接