在没有django预先构建的表单的情况下,如何使用视图填充manytomanyfield?

时间:2019-10-28 13:21:21

标签: python django manytomanyfield

我正在使用django构建存储Web系统,我在框架上非常新手,所以问题是,存在一个业务规则,该规则要求两种产品,内部产品和最终产品那些。最终的数据总是由一个或多个内部产品组成,我有使用多方领域的想法,但是现在,我真的不知道如何从形式和形式中提取该数据,这应该是一个选择。保存在数据库中,是否有人有任何提示或更好的主意?

Models.py

+---+-------+-------+----+
| id|target1|target2|col6|
+---+-------+-------+----+
|  1|      a|      b|   c|
|  2|      a|      b|   c|
|  3|      a|      b|   c|
|  4|      a|      b|   c|
+---+-------+-------+----+

+---+-------+-------+----+
| id|target1|target2|col6|
+---+-------+-------+----+
|  1|   null|   null|   c|
|  2|   null|   null|   c|
|  3|   null|   null|   c|
|  4|   null|   null|   c|
+---+-------+-------+----+

root
 |-- id: long (nullable = false)
 |-- target1: string (nullable = true)
 |-- target2: string (nullable = true)
 |-- col6: string (nullable = true)

Views.py

class Produto(models.Model):
    codigo = models.CharField(max_length=254, null=True)
    produto_desc = models.CharField(max_length=200, null=False)
    tipo = models.CharField(max_length=2)
    qtd = models.IntegerField(null=True, default=0)
    created = models.DateTimeField(default=timezone.now, editable=False)
    last_updated = models.DateTimeField(default=timezone.now, editable=False)


    #Relationship Fields
    estrutura = models.ManyToManyField(
        'storage.Produto',
        related_name="produto"
    )

    def __str__(self):
        return self.produto_desc

forms.py

def CadastroProd(request):
    temp = 0


    lista_produto = Produto.objects.order_by('id')[:20]
    for i in lista_produto:
        temp += 1
    if request.method == 'POST':
        form = NovoProduto(request.POST)
        if form.is_valid():
            obj = Produto()
            obj.save(commit=False)

            obj.codigo = form.cleaned_data['codigo']
            obj.produto_desc = form.cleaned_data['produto_desc']
            obj.tipo = form.cleaned_data['tipo']
            # obj.estrutura = form.cleaned_data['estrutura']
            obj.save()

            return HttpResponseRedirect('/storage/produtos')

    lista_produto = Produto.objects.order_by('id')[:20]
    lista_pi = Produto.objects.filter(tipo='PI')
    lista_pa = Produto.objects.filter(tipo='PA')

    context = {'lista_produto': lista_produto,
               'temp': temp,
               'lista_pi': lista_pi, 'lista_pa': lista_pa,
               }

    return render(request, 'storage/cadproduto/cadproduto.html', context)

索引

class NovoProduto(forms.Form):
    codigo = forms.CharField(label='codigo', max_length=254)
    produto_desc = forms.CharField(label='produto_desc', max_length=100)
    tipo = forms.CharField(label='tipo', max_length=2)
    estrutura = forms.IntegerField()

我希望我能够获得该产品的信息以及组成该产品的产品

2 个答案:

答案 0 :(得分:0)

您正在使用自己的自定义模板,因此请使用 getlist()方法获取选定的选项列表,并使用 set()方法保存这样的manytomany字段 另外,如果表格有效,则需要保存表格

accept

答案 1 :(得分:0)

在您的Form子类中,使用ModelMultipleChoiceField

class NovoProduto(forms.Form):
    codigo = forms.CharField(label='codigo', max_length=254)
    produto_desc = forms.CharField(label='produto_desc', max_length=100)
    tipo = forms.CharField(label='tipo', max_length=2)
    estrutura = forms.ModelMultipleChoiceField(queryset=Produto.objects.order_by('id')[:20])

“ M2M”字段似乎是一个自引用(除非您有两个名为Produto的模型),因此您可能希望将当前产品从选择选项列表中排除。

您可以在表单的构造函数中修改ModelMultipleChoiceField的查询集:

    def __init__(*args, **kwargs):
        super().__init__(*args, **kwargs)
        if self.instance and self.instance.id:
            self.fields['estrutura'].queryset = Produto.objects.exclude(id=self.instance.id).order_by('id')[:20]