Django - 未正确检索POST请求

时间:2013-07-11 23:31:09

标签: django

我正在Django中进行库存控制,我想要一个表单来控制将要进行的操作。如果产品的记录已存在,则应更新数量。如果它不存在,它应该为它创建记录。除此之外,一个表单字段将有三个选择。一个将表格值添加到que产品数量,另一个将减去,另一个将更改为表格中的值。

模型非常大,因为我为表单字段设置了一些选项。那是:

from django.db import models
from django import forms
from django.forms import ModelForm

class Produto(models.Model):
    CAMISA = "CM"
    QUADRO = "QD"
    CANECA = 'CN'
    ESCOLHAS_PRODUTO = (
        (CAMISA, 'Camisa'),
        (QUADRO, 'Quadro'),
        (CANECA, 'Caneca'),
    )
    tipo = models.CharField(max_length = 40,
                            choices=ESCOLHAS_PRODUTO,
                            default=CAMISA)

class Camisa(Produto):    

    MASCULINA = 'MA'
    FEMININA_BASICA = 'FB'
    FEMININA_GOLA_V = 'FV'
    INFANTIL = 'IN'
    MODELO_CAMISA = (
        (MASCULINA, 'Masculina'),
        (FEMININA_BASICA, 'Feminina Basica'),
        (FEMININA_GOLA_V, 'Feminina Gola V'),
        (INFANTIL, 'Infantil'),
    )
    modelo = models.CharField(max_length = 50,
                              choices=MODELO_CAMISA,
                              )

    AMARELA = 'AM'
    AZUL_CLARO = 'AC'
    AZUL_ESCURO = 'AE'
    BRANCA = 'BR'
    CINZA = 'CI'
    LARANJA = 'LA'
    MARFIM = 'MA'
    ROSA = 'RO'
    PRETA = 'PR'
    VERDE_MUSGO = 'VM'
    VERMELHA = 'VR'
    CORES_CAMISA = (
        (AMARELA, 'Amarela'),
        (AZUL_CLARO, 'Azul Claro'),
        (AZUL_ESCURO, 'Azul Escuro'),
        (BRANCA, 'Branca'),
        (CINZA, 'Cinza'),
        (LARANJA, 'Laranja'),
        (MARFIM, 'Marfim'),
        (ROSA, 'Rosa'),
        (PRETA, 'Preta'),
        (VERDE_MUSGO, 'Verde Musgo'),
        (VERMELHA, 'Vermelha'),
    )
    cor = models.CharField(max_length = 40,
                                    choices=CORES_CAMISA,
                                    )

    TAMANHO_P = 'TP'
    TAMANHO_M = 'TM'
    TAMANHO_G = 'TG'
    TAMANHO_GG = 'GG'
    TAMANHO_XG = 'XG'
    TAMANHO_02_ANOS = '02'
    TAMANHO_04_ANOS = '04'
    TAMANHO_06_ANOS = '06'
    TAMANHO_08_ANOS = '08'
    TAMANHO_10_ANOS = '10'
    TAMANHO_12_ANOS = '12'
    TAMANHO_14_ANOS = '14'
    TAMANHO_CAMISA = (
        (TAMANHO_P, 'P'),
        (TAMANHO_M, 'M'),
        (TAMANHO_G, 'G'),
        (TAMANHO_GG, 'GG'),
        (TAMANHO_XG, 'XGG'),
        (TAMANHO_02_ANOS, '2 Anos'),
        (TAMANHO_04_ANOS, '4 Anos'),
        (TAMANHO_06_ANOS, '6 Anos'),
        (TAMANHO_08_ANOS, '8 Anos'),
        (TAMANHO_10_ANOS, '10 Anos'),
        (TAMANHO_12_ANOS, '12 Anos'),
        (TAMANHO_14_ANOS, '14 Anos'),
    )
    tamanho= models.CharField(max_length = 50,
                              choices=TAMANHO_CAMISA,
                              )




    quantidade = models.IntegerField()

    def __unicode__(self):
        return self.modelo


class CamisaForm(ModelForm):
    ADICIONAR = 'ADC'
    REDUZIR = 'RED'
    ALTERAR = 'ALT'    
    ACOES = (
        (ADICIONAR, 'Adicionar Quantidade'),
        (REDUZIR, 'Reduzir Quantidade'),
        (ALTERAR, 'Alterar para Quantidade'),        
    )
    acoes = forms.ChoiceField(
                              choices=ACOES,
                              )

    class Meta:
        model = Camisa

以下观点:

def index(request):
    produtos_estoque = Camisa.objects.all()
    template = 'estoque/index.html'
    modelos_camisa = {'MA' : 'Masculina Basica','FB' : 'Feminina Basica','FV' : 'Feminina Gola V','IN' : 'Infantil' }
    if request.method == 'POST':
        form = CamisaForm(request.POST)
        if form.is_valid():                
            try:
                produto_atualizar = Camisa.objects.get(modelo = request.POST['modelo'], cor = request.POST['cor'], tamanho = request.POST['tamanho'])            
                if request.POST['acoes'] == 'ADC':
                    produto_atualizar.quantidade = produto_atualizar.quantidade + request.POST['quantidade']
                elif request.POST['acoes'] == 'RED':
                    produto_atualizar.quantidade = produto_atualizar.quantidade - request.POST['quantidade']
                elif request.POST['acoes'] == 'ALT':
                    produto_atualizar.quantidade = request.POST['quantidade']
                produto_atualizar.save()
            except:
                produto_atualizar = form.save()
            return HttpResponseRedirect('')
    else:
        form = CamisaForm()
    return render_to_response(template, { 'form': form, 'produtos_estoque': produtos_estoque,
        'modelos_camisa' : modelos_camisa.iteritems(),  }, context_instance=RequestContext(request))

但正在发生的事情是,表单只是为产品创建了另一条记录,即使它已经存在。不确定模型的其余部分是否对此问题很重要,如有必要,将发布。有人可以帮我这个吗?感谢

1 个答案:

答案 0 :(得分:1)

请发布它正在执行的模型 - 它会有一些有用的信息,比如约束或缺少等等。好酷,没有造成插入违规的唯一约束。

我建议首先使用表单cleaned_data来访问表单值而不是原始POST数据,form.is_valid()做了大量工作来将原始数据处理为模型数据的可接受输入。

第二件事是except子句将捕获 ANY 异常,我怀疑这是你的问题......在{{1}创建新记录时出现了其他问题}子句。具体,如except

第三件事是将这些常量放在Model上,这样你就可以从Form和View中引用它们而不是文字字符串。这只是清洁/代码风格的推荐。

一点点清理可能看起来像:

except Camisa.DoesNotExist:

(对不起任何语法错误,我的葡萄牙语不太好)

这应该足以让你入门,如果你添加更多信息我可以编辑并详细说明我的答案。祝你好运!