ChatGPT解决这个技术问题 Extra ChatGPT

可以在创建时将字典传递给 django 模型吗?

是否可以用 listdictionary 或其他东西做类似的事情?

data_dict = {
    'title' : 'awesome title',
    'body' : 'great body of text',
}

Model.objects.create(data_dict)

如果我可以扩展它,那就更好了:

Model.objects.create(data_dict, extra='hello', extra2='world')

A
Alasdair

如果 titlebody 是模型中的字段,则 you can deliver the keyword arguments in your dictionary using the ** operator

假设您的模型名为 MyModel

# create instance of model
m = MyModel(**data_dict)
# don't forget to save to database!
m.save()

至于你的第二个问题,字典必须是最后的论据。同样,extraextra2 应该是模型中的字段。

m2 =MyModel(extra='hello', extra2='world', **data_dict)
m2.save()

谢谢,这正是我想要做的。另外,作为旁注,仅基于您的帖子。使用 Model.objects.create(**data_dict) 时不必调用 save 方法。您可能已经知道这一点,但只是提醒一下。
我以前没有使用过 objects.create 方法,所以你教会了我一些新东西。
objects.create 还返回一个指向新模型的指针,其中填充了有效的 pk。这意味着您可以立即使用它来构建相关模型。
我被ForeignKey咬了。如果您的模型有一个名为 ownerForeignKey,那么您的 data_dict 应该有一个 owner_id 字段。但是 django.forms.model_to_dict() 返回一个带有 owner 字段的字典。所以你不能做 MyModel(**model_to_dict(my_instance));您必须将 owner 字段重命名为 owner_id
在 1.5.4 中,外键(添加 _id)对我不起作用。对于 MTM 关系,我不得不做一些更像 modelinstance.save()、modelinstance.add(foreignobject.id) 的事情。不过谢谢。这确实帮助我走上了正确的轨道,让它发挥作用。
c
codehia

对于任何模型 DummyModel,您都可以使用 DummyModel.objects.create(**data_dict)。创建后不需要保存。


L
Luke Dupin

不是直接回答这个问题,但我发现这段代码帮助我创建了可以很好地保存到正确答案中的字典。如果此数据将导出为 json,则需要进行类型转换。

我希望这有帮助:

  #mod is a django database model instance
def toDict( mod ):
  import datetime
  from decimal import Decimal
  import re

    #Go through the object, load in the objects we want
  obj = {}
  for key in mod.__dict__:
    if re.search('^_', key):
      continue

      #Copy my data
    if isinstance( mod.__dict__[key], datetime.datetime ):
      obj[key] = int(calendar.timegm( ts.utctimetuple(mod.__dict__[key])))
    elif isinstance( mod.__dict__[key], Decimal ):
      obj[key] = float( mod.__dict__[key] )
    else:
      obj[key] = mod.__dict__[key]

  return obj 

def toCsv( mod, fields, delim=',' ):
  import datetime
  from decimal import Decimal

    #Dump the items
  raw = []
  for key in fields:
    if key not in mod.__dict__:
      continue

      #Copy my data
    if isinstance( mod.__dict__[key], datetime.datetime ):
      raw.append( str(calendar.timegm( ts.utctimetuple(mod.__dict__[key]))) )
    elif isinstance( mod.__dict__[key], Decimal ):
      raw.append( str(float( mod.__dict__[key] )))
    else:
      raw.append( str(mod.__dict__[key]) )

  return delim.join( raw )