【问题标题】:Django - How ModelChoiceField queryset's works?Django - ModelChoiceField 查询集如何工作?
【发布时间】:2013-03-14 06:02:58
【问题描述】:

我有一个带有 ModelChoiceField 的表单,我想从我的数据库中加载一个表。如果我在表单的初始化中使用这个查询集,那么我的视图的 form.is_valid 可以正常工作:

self.fields['categoria_formfield'].queryset = sitio_categoria.objects.exclude(categoria='patrimonio').values_list('idCategoria',flat=True)

该代码在 ModelChoiceField 上显示一个 id 列表,但我需要的是显示类别列表。所以我使用:

self.fields['categoria_formfield'].queryset = sitio_categoria.objects.exclude(categoria='patrimonio').values_list('categoria',flat=True)

但是使用此代码 .is_valid 不验证,我收到一个表单错误:“选择一个有效的选择。该选择不是可用的选择之一。”关于可能是什么问题的一些线索?

型号

class sitio_categoria(models.Model):
    idCategoria         =   models.AutoField(primary_key=True)
    categoria           =   models.CharField(max_length=30, null=False, unique=True)

表格

class anadirComercioPaso1_form(forms.Form):
        categoria_formfield = forms.ModelChoiceField(widget=forms.Select(attrs={'size':'13', 'onchange':'this.form.action=this.form.submit()'}), queryset=sitio_categoria.objects.none())

def __init__(self, *args, **kwargs):
        super(anadirComercioPaso1_form, self).__init__(*args,**kwargs)
        self.fields['categoria_formfield'].queryset = sitio_categoria.objects.exclude(categoria='patrimonio').values_list('categoria',flat=True)

【问题讨论】:

    标签: django forms validation dynamic-forms


    【解决方案1】:

    不要使用values_list,(或values),ModelChoiceField需要实际的模型对象。

    queryset = sitio_categoria.objects.exclude(categoria='patrimonio')
    

     

    ModelChoiceField 将使用对象的主键进行验证,并使用它们的 unicode 表示进行显示。因此,您需要在模型中定义转换为 unicode:

    class sitio_categoria(models.Model):
        idCategoria = models.AutoField(primary_key=True)
        categoria = models.CharField(max_length=30, null=False, unique=True)
    
        def __unicode__(self):
            return self.categoria
    

     

    ModelChoiceField documentation

    将调用模型的__unicode__ 方法来生成对象的字符串表示形式,以用于字段的选择;

    【讨论】:

      猜你喜欢
      • 2014-11-15
      • 2013-03-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-11-01
      • 2016-08-28
      相关资源
      最近更新 更多