django框架model orM使用字典作為參數(shù),保存數(shù)據(jù)的方法分析
本文實例講述了django框架model orM使用字典作為參數(shù),保存數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
假設(shè)有一個字典,里面已經(jīng)有了所有相關(guān)信息,現(xiàn)在想利用這個字典作為參數(shù),跟django model 結(jié)合,用很少的代碼量保存數(shù)據(jù),有什么簡便方法,比如有如下定義的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',
}
如果按照常規(guī)的做法,可能采用如下方式去保存數(shù)據(jù):
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里面去取得數(shù)據(jù)。
其實還有更簡單的方法,直接傳入這個dict數(shù)據(jù),但前提是: 字典數(shù)據(jù)里面的key 字段一定要與model中定義的field 對應(yīng),否則就會報錯.但事實上在封裝dict數(shù)據(jù)的時候,完全可以對應(yīng)的。用如下方法保存
mymodel = MyModel(**data_dict) mymodel.save()
如果還有一些其他的擴展字段,也是可以加在里面的,但注意. **data_dict 必須放在最后:
mymodel =MyModel(extra='hello', extra2='world', **data_dict) mymodel .save()
還可以這樣做:
MyModel.objects.create(**data_dict)
這樣就只是實現(xiàn)了django model保存dict ,并且還可以擴展
2013-01-04日更新:最近在一篇文章中發(fā)現(xiàn),如果要用字典dict作為參數(shù)更新一個model的方法如下:
mymodel=MyModel.objects.get(pk=pk)#....找到唯一的一個,自行修改 mymodel.__dict__.update(data_dict ) mymodel.save()
當然也有用如下方式實現(xiàn)更新的:
MyModel.objects.filter(pk=pk).update(**data_dict )
希望本文所述對大家基于Django框架的Python程序設(shè)計有所幫助。
相關(guān)文章
python訪問mysql數(shù)據(jù)庫的實現(xiàn)方法(2則示例)
這篇文章主要介紹了python訪問mysql數(shù)據(jù)庫的實現(xiàn)方法,結(jié)合實例形式分析了兩種Python操作MySQL數(shù)據(jù)庫的相關(guān)技巧,需要的朋友可以參考下2016-01-01
Python PyQt5實戰(zhàn)項目之文件拷貝器的具體實現(xiàn)詳解
PyQt5以一套Python模塊的形式來實現(xiàn)功能。它包含了超過620個類,600個方法和函數(shù)。本篇文章手把手帶你用PyQt5實現(xiàn)一個簡單的文件拷貝器,大家可以在過程中查缺補漏,提升水平2021-11-11
Python實現(xiàn)刪除列表中滿足一定條件的元素示例
這篇文章主要介紹了Python實現(xiàn)刪除列表中滿足一定條件的元素,結(jié)合具體實例形式對比分析了Python針對列表元素的遍歷、復(fù)制、刪除等相關(guān)操作技巧,需要的朋友可以參考下2017-06-06

