在django中自定義字段Field詳解
Django的Field類中方法有:
to_python() # 把數(shù)據(jù)庫數(shù)據(jù)轉(zhuǎn)成python數(shù)據(jù)
from_db_value() # 把數(shù)據(jù)庫數(shù)據(jù)轉(zhuǎn)成python數(shù)據(jù)
get_pre_value() # 把python數(shù)據(jù)壓縮準備存入數(shù)據(jù)庫
get_db_pre_value() # 把壓縮好的數(shù)據(jù)轉(zhuǎn)成數(shù)據(jù)庫查詢集
get_prep_lookup() # 指定過濾的條件
value_to_string() # 數(shù)據(jù)序列化
如果創(chuàng)建的Field比字符串,日期,整數(shù)等更復(fù)雜的數(shù)據(jù)結(jié)構(gòu),可能需要重寫to_python 和from_db_value()方法(Django提供的一個SubfileBase元類,他在賦值時總是調(diào)用to_python()
一個簡單的ListField 字段類型
# _*_ coding:utf-8 _*_ from django.db import models import ast class ListField(models.TextField): """自定義list字段 models.SubfieldBase 提供to_python 和 from_db_value 把數(shù)據(jù)庫數(shù)據(jù)轉(zhuǎn)化成python數(shù)據(jù) 現(xiàn)在主要是from_db_value 方法 把數(shù)據(jù)庫數(shù)據(jù)轉(zhuǎn)化成python數(shù)據(jù) to_python 主要是接受form表單 """ __metacalss__ = models.SubfieldBase description = 'Stores a python list' def __init__(self, *args, **kwargs): super(ListField,self).__init__(*args, **kwargs) # def db_type(self, connection): # if connection.setting_dict['ENGINE'] == 'django.db.backends.mysql': # return 'listtype' def from_db_value(self,value,expression,connection,context): """數(shù)據(jù)庫數(shù)據(jù)轉(zhuǎn)成python數(shù)據(jù)""" if value is None: value=[] return value if isinstance(value,list): return value return ast.literal_eval(value) def to_python(self, value): """從數(shù)據(jù)庫中讀取的數(shù)據(jù)轉(zhuǎn)成python eval(value)讀取value原來的類型 ast模塊就是幫助Python應(yīng)用來處理抽象的語法解析的。 而該模塊下的literal_eval()函數(shù): 則會判斷需要計算的內(nèi)容計算后是不是合法的python類型, 如果是則進行運算,否則就不進行運算。 """ if not value: value = [] if isinstance(value, list): return value return ast.literal_eval(value) def get_prep_value(self, value): """ 把python數(shù)據(jù)壓縮后保存到數(shù)據(jù)庫 或者說把python對象轉(zhuǎn)化成查詢值 返回值是個字符串 :param value: :return: """ if value is None: return value return str(value) # def get_db_prep_value(self, value, connection, prepared=False): # """把查詢集數(shù)據(jù)轉(zhuǎn)化成數(shù)據(jù)庫值 一般不需要重寫 只需要覆蓋""" # value = super(ListField, self).get_db_prep_value() # if value is not None: # return connection.Database.Binary(value) # return value # def get_prep_lookup(self, lookup_type, value): """限制查詢方式""" if lookup_type == 'exact': return value elif lookup_type == 'in': return [self.get_prep_value(v) for v in value] else: return TypeError('lookup type %r not supported'%lookup_type) def value_to_string(self, obj): """轉(zhuǎn)換字段數(shù)據(jù)以進行序列化 Field._get_val_from_obj(obj) 是獲取值序列化的最佳方式 """ value = self._get_val_from_obj(obj) return self.get_db_prep_value(value)
以上這篇在django中自定義字段Field詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
python將字符串轉(zhuǎn)變成dict格式的實現(xiàn)
這篇文章主要介紹了python將字符串轉(zhuǎn)變成dict格式的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11python計算程序開始到程序結(jié)束的運行時間和程序運行的CPU時間
這篇文章主要介紹了python計算程序開始到程序結(jié)束的運行時間和程序運行的CPU時間的三個方法,大家參考使用2013-11-11Python激活A(yù)naconda環(huán)境變量的詳細步驟
今天給大家分享Python激活A(yù)naconda環(huán)境變量的詳細步驟,激活A(yù)naconda環(huán)境變量分為簡潔版和詳細版,簡潔版只需要通過輸入命令進行配置即可,詳細版本文通過圖文步驟給大家介紹的非常詳細,需要的朋友參考下吧2021-06-06淺談Django中view對數(shù)據(jù)庫的調(diào)用方法
今天小編就為大家分享一篇淺談Django中view對數(shù)據(jù)庫的調(diào)用方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07