作者:轻舞肥羊 日期:2012-12-31
假设有一个字典,里面已经有了所有相关信息,现在想利用这个字典作为参数,跟django model 结合,用很少的代码量保存数据,有什么简便方法,比如有如下定义的model:
from django.db import models
class MyModel(models.Model):
title=models.CharField(max_length=250)
body= models.CharField(max_length=1000)
....
有一个字典:
data_dict = {
'title' : 'awesome title',
'body' : 'great body of text',
}
如果按照常规的做法,可能采用如下方式去保存数据:
mymodel = MyModel()
mymodel.title = data_dict['title']
mymodel.bdy = data_dict['body']
mymodel.save()
或者这样
mymodel = MyModel(title=data_dict['title'],body=data_dict['body'])
mymodel.save()
其实是一样的,从dict里面去取得数据。
其实还有更简单的方法,直接传入这个dict数据,但前提是: 字典数据里面的key 字段一定要与model中定义的field 对应,否则就会报错.但事实上在封装dict数据的时候,完全可以对应的。用如下方法保存
mymodel = MyModel(**data_dict)
mymodel.save()
如果还有一些其他的扩展字段,也是可以加在里面的,但注意. **data_dict 必须放在最后:
mymodel =MyModel(extra='hello', extra2='world', **data_dict)
mymodel .save()
还可以这样做:
MyModel.objects.create(**data_dict)
这样就只是实现了django model保存dict ,并且还可以扩展
2013-01-04日更新:最近在一篇文章中发现,如果要用字典dict作为参数更新一个model的方法如下:
mymodel=MyModel.objects.get(pk=pk)#....找到唯一的一个,自行修改
mymodel.__dict__.update(data_dict )
mymodel.save()
当然也有用如下方式实现更新的:
MyModel.objects.filter(pk=pk).update(**data_dict )
程序代码
from django.db import models
class MyModel(models.Model):
title=models.CharField(max_length=250)
body= models.CharField(max_length=1000)
....
有一个字典:
程序代码
data_dict = {
'title' : 'awesome title',
'body' : 'great body of text',
}
如果按照常规的做法,可能采用如下方式去保存数据:
程序代码
mymodel = MyModel()
mymodel.title = data_dict['title']
mymodel.bdy = data_dict['body']
mymodel.save()
或者这样
程序代码
mymodel = MyModel(title=data_dict['title'],body=data_dict['body'])
mymodel.save()
其实是一样的,从dict里面去取得数据。
其实还有更简单的方法,直接传入这个dict数据,但前提是: 字典数据里面的key 字段一定要与model中定义的field 对应,否则就会报错.但事实上在封装dict数据的时候,完全可以对应的。用如下方法保存
程序代码
mymodel = MyModel(**data_dict)
mymodel.save()
如果还有一些其他的扩展字段,也是可以加在里面的,但注意. **data_dict 必须放在最后:
程序代码
mymodel =MyModel(extra='hello', extra2='world', **data_dict)
mymodel .save()
还可以这样做:
程序代码
MyModel.objects.create(**data_dict)
这样就只是实现了django model保存dict ,并且还可以扩展
2013-01-04日更新:最近在一篇文章中发现,如果要用字典dict作为参数更新一个model的方法如下:
程序代码
mymodel=MyModel.objects.get(pk=pk)#....找到唯一的一个,自行修改
mymodel.__dict__.update(data_dict )
mymodel.save()
当然也有用如下方式实现更新的:
程序代码
MyModel.objects.filter(pk=pk).update(**data_dict )