python - 使用表单字段更新 Django 模型

标签 python django django-models django-forms

我正在尝试使用前端的整数表单字段来更新库存模型的数量。我可以添加新的库存商品,但我想更新现有商品。这是我的代码:

来自 VIEWS.PY

def view_inventory(request, slug):

if request.method == 'POST':
    quantity_add = addQuantity(request.POST)
    if quantity_add.is_valid():
        cd = quantity_add.cleaned_data
        addq=Inventory(quantity = cd.get('quantity'))
        addq.save()

quantity_add=addQuantity()

return render(request, 'inv/view_inventory.html', {
    'item': get_object_or_404(Inventory.objects.all(), slug=slug),
    'form' : quantity_add,
    })

来自模型.PY

class Inventory(models.Model):
    quantity = models.IntegerField()
    name = models.CharField(max_length=150, unique = True)
    slug = models.SlugField(unique = True)
    date = models.DateTimeField(auto_now_add=True)
    description = models.CharField(max_length=250)
    category    = models.ForeignKey(Category, null=True, blank=True)
    def __unicode__(self):
        return self.name
    @permalink
    def get_absolute_url(self):
        return ('view_inventory', None, { 'slug' : self.slug })

    class Meta:
        ordering = ['-date']

来自 URLS.PY

url(r'^(?P<slug>[\w\-]+)/$', 'inv.views.view_inventory', name='view_inventory'),

最佳答案

您只需获取记录然后更新它:

 def view_inventory(request, slug):

  if request.method == 'POST':
        quantity_add = addQuantity(request.POST)
        if quantity_add.is_valid():
            cd = quantity_add.cleaned_data
            old_inventory = Inventory.objects.get(id=something here) #id or pk or whatever you want
            old_inventory.quantity = cd.get('quantity')
            old_inventory.save()

    quantity_add=addQuantity()

    return render(request, 'inv/view_inventory.html', {
        'item': get_object_or_404(Inventory.objects.all(), slug=slug),
        'form' : quantity_add,
        })

关于python - 使用表单字段更新 Django 模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18948262/

相关文章:

python - 小数点后各占一行的值。使用 Python 3+ 实现 CSV

javascript - 根据传递的 url 参数单击表单按钮

python - MySQLdb/_mysql.c(29) : fatal error C1083: Cannot open include file: 'mysql.h' : No such file or directory

django - 使用 Django 根据记录中的字段高效更新大量记录

django ajax/jquery 文件上传

python - django.db.utils.IntegrityError : UNIQUE constraint failed: rango_page__new. category_id

python - 将 json 数据保存到 Django 模型

java - 在java和python之间传递数据

python - Django 多处理异常

python-3.x - 单一 View 中的多模型表单集工厂