您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關(guān)django中怎么自定義字段Field,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
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ù)壓縮準(zhǔn)備存入數(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ù): 則會判斷需要計(jì)算的內(nèi)容計(jì)算后是不是合法的python類型, 如果是則進(jìn)行運(yùn)算,否則就不進(jìn)行運(yùn)算。 """ 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ù)以進(jìn)行序列化 Field._get_val_from_obj(obj) 是獲取值序列化的最佳方式 """ value = self._get_val_from_obj(obj) return self.get_db_prep_value(value)
看完上述內(nèi)容,你們對django中怎么自定義字段Field有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。