Django model轉字典的幾種方法

2021-09-11 11:28:33 字數 3892 閱讀 5565

平常的開發過程中不免遇到需要把model轉成字典的需求,尤其是現在流行前後端分離架構,json格式幾乎成了前後端之間資料交換的標準,這種model轉dict的需求就更多了,本文介紹幾種日常使用的方法以供參考,所有例子均基於django 2.0環境演示

model內容如下:

class group(models.model):

name = models.charfield(max_length=255, unique=true, verbose_name='組名稱')

def __str__(self):

return self.name

class user(models.model):

create_time = models.datetimefield(auto_now_add=true, verbose_name='建立時間')

update_time = models.datetimefield(auto_now=true, verbose_name='更新時間')

username = models.emailfield(max_length=255, unique=true, verbose_name='使用者名稱')

fullname = models.charfield(max_length=64, null=true, verbose_name='中文名')

is_active = models.booleanfield(default=true, verbose_name='啟用狀態')

leader = models.foreignkey('self', null=true, on_delete=models.cascade, verbose_name='上級')

group = models.manytomanyfield(group, null=true, verbose_name='所屬組')

def __str__(self):

return self.username

複製**

需求很簡單就是分別把group和user表中的資料轉換成字典格式返回

示例**:

>>> _t = group.objects.get(id=1)

>>>

>>> dict =

>>>

>>> print(dict)

複製**

這種方法的好處是方便控制最終返回字典value的格式,例如對於user表,我想返回最終的資料是id、建立時間、中文名、上級中文名、所屬組名列表的話可以用下邊的**實現

>>> _t = user.objects.get(id=2)

>>>

>>> dict =

>>>

>>> print(dict)

>>>

複製**

缺點也很明顯,就是如果乙個model欄位很多且不需要轉換value格式的時候需要寫大量冗餘的**,這種問題怎麼解決呢?且看下邊的方法介紹

示例**:

>>> group.objects.get(id=1).__dict__

>>>

>>> user.objects.get(id=1).__dict__

複製**

這種方法優點就是寫法簡單,容易理解,**量還少

但會發現多了個沒用的_state字段,同時foreignkey欄位名多了_id,也沒有manytomanyfield欄位的資料,且不能按需顯示輸出,當我只需要其中幾個字段時會有大量冗餘資料

示例**:

>>> model_to_dict(group.objects.get(id=1))

>>>

>>> model_to_dict(user.objects.get(id=2))

複製**

這種方法能滿足大部分的需求,且輸出也較為合理,同時還有兩個引數fieldsexclude來配置輸出的字段,例如:

>>> model_to_dict(user.objects.get(id=2), fields=['fullname','is_active'])

>>>

>>> model_to_dict(user.objects.get(id=2), exclude=['group','leader','id'])

複製**

但是會跳過有editable=false屬性欄位的展示,對於有auto_now_add=trueauto_now=true屬性的datetime欄位會預設新增editable=false隱藏屬性,這也是上邊兩個time相關字段create_timeupdate_time轉換成dict後不顯示的原因,官方相關原始碼如下:

for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):

if not getattr(f, 'editable', false):

continue

複製**

示例**:

from django.db.models.fields import datetimefield

from django.db.models.fields.related import manytomanyfield

class user(models.model):

...def to_dict(self, fields=none, exclude=none):

data = {}

for f in self._meta.concrete_fields + self._meta.many_to_many:

value = f.value_from_object(self)

if fields and f.name not in fields:

continue

if exclude and f.name in exclude:

continue

if isinstance(f, manytomanyfield):

value = [ i.id for i in value ] if self.pk else none

if isinstance(f, datetimefield):

value = value.strftime('%y-%m-%d %h:%m:%s') if value else none

data[f.name] = value

return data

複製**

執行結果:

>>> user.objects.get(id=2).to_dict

()>>>

>>> user.objects.get(id=2).to_dict(fields=['fullname','is_active','create_time'])

>>>

>>> user.objects.get(id=2).to_dict(exclude=['group','leader','id','create_time'])

複製**

擁有model_to_dict一樣的便利性,同時也解決了不能輸出time時間字段(editable=false)的問題,還能對value按照自己需要的格式輸出,一舉多得 當然擁有便利性的同時需要自己實現to_dict的**,增加了複雜度

Django model轉字典的幾種方法

平常的開發過程中不免遇到需要把model轉成字典的需求,尤其是現在流行前後端分離架構,json格式幾乎成了前後端之間資料交換的標準,這種model轉dict的需求就更多了,本文介紹幾種日常使用的方法以供參考,所有例子均基於django 2.0環境演示 model內容如下 class group mo...

Django model轉字典的幾種方法

平常的開發過程中不免遇到需要把model轉成字典的需求,尤其是現在流行前後端分離架構,json格式幾乎成了前後端之間資料交換的標準,這種model轉dict的需求就更多了,本文介紹幾種日常使用的方法以供參考,所有例子均基於django 2.0環境演示 model內容如下 class group mo...

json 轉字典 字典轉json

brief 把格式化的json格式的字串轉換成字典 param jsonstring json格式的字串 return 返回字典 json格式字串轉字典 nsdictionary dictionarywithjsonstring nsstring jsonstring nsdata jsondata...