如何在Django Db记录中设置多个字段

Bri*_*her 2 python django django-models

我想知道为现有Django模型对象的多个字段设置值的最佳方法.我有一个包含许多领域的模型:

class Foo(models.Model):
    Field1 = models.CharField(max_length=40)
    Field2 = models.CharField(max_length=40)
    Field3 = models.CharField(max_length=40)
    etc...
Run Code Online (Sandbox Code Playgroud)

此外,我还有一个字典,其中包含对特定记录的这些字段的子集的更改:

data = {'field1': 'value1', 'field5': 'value5', 'field7': 'value7'}
record = Foo.objects.get(pk=1)
Run Code Online (Sandbox Code Playgroud)

我想record用新值设置字段data.最好的方法是什么?有没有办法解压缩字典并让它修改记录中的相应字段?我意识到我可以使用以下方法迭代字典:

for k, v in data.iteritems():
     setattr(entry, k, v)
entry.save()
Run Code Online (Sandbox Code Playgroud)

我在想可能有办法打电话:

entry.set_values(**data)
Run Code Online (Sandbox Code Playgroud)

有这样的事情,还是我走错了路?

Bra*_*don 5

我自己没有测试过这个,但你可以将一个dict传递给Queryset API中的.update()函数:https://docs.djangoproject.com/en/2.0/ref/models/querysets/#update

Foo.objects.get(pk=1).update(**data)
Run Code Online (Sandbox Code Playgroud)

  • 更新仅适用于查询集,但这适用于Foo.objects.filter(pk = 1).update(**data).谢谢你的建议. (4认同)
  • 请注意,这不会触发任何与保存相关的信号,也不会在实例上调用.save()。这可能是理想情况,或者是破坏交易的行为。您可以执行`Foo.objects.filter(pk = 1).update(** date); Foo.objects.get(pk = 1).save()`,如果您需要触发它。 (2认同)