在django中自定義字段Field詳解
Django的Field類中方法有:
to_python() # 把數(shù)據(jù)庫(kù)數(shù)據(jù)轉(zhuǎn)成python數(shù)據(jù)
from_db_value() # 把數(shù)據(jù)庫(kù)數(shù)據(jù)轉(zhuǎn)成python數(shù)據(jù)
get_pre_value() # 把python數(shù)據(jù)壓縮準(zhǔn)備存入數(shù)據(jù)庫(kù)
get_db_pre_value() # 把壓縮好的數(shù)據(jù)轉(zhuǎn)成數(shù)據(jù)庫(kù)查詢集
get_prep_lookup() # 指定過(guò)濾的條件
value_to_string() # 數(shù)據(jù)序列化
如果創(chuàng)建的Field比字符串,日期,整數(shù)等更復(fù)雜的數(shù)據(jù)結(jié)構(gòu),可能需要重寫(xiě)to_python 和from_db_value()方法(Django提供的一個(gè)SubfileBase元類,他在賦值時(shí)總是調(diào)用to_python()
一個(gè)簡(jiǎn)單的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ù)庫(kù)數(shù)據(jù)轉(zhuǎn)化成python數(shù)據(jù)
現(xiàn)在主要是from_db_value 方法 把數(shù)據(jù)庫(kù)數(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ù)庫(kù)數(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ù)庫(kù)中讀取的數(shù)據(jù)轉(zhuǎn)成python
eval(value)讀取value原來(lái)的類型
ast模塊就是幫助Python應(yīng)用來(lái)處理抽象的語(yǔ)法解析的。
而該模塊下的literal_eval()函數(shù):
則會(huì)判斷需要計(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ù)庫(kù)
或者說(shuō)把python對(duì)象轉(zhuǎn)化成查詢值
返回值是個(gè)字符串
: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ù)庫(kù)值 一般不需要重寫(xiě) 只需要覆蓋"""
# 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)
以上這篇在django中自定義字段Field詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python 如何利用pandas 和 matplotlib繪制柱狀圖
Python 中的 pandas 和 matplotlib 庫(kù)提供了豐富的功能,可以幫助你輕松地繪制各種類型的圖表,本文將介紹如何使用這兩個(gè)庫(kù),繪制一個(gè)店鋪銷售數(shù)量的柱狀圖,并添加各種元素,如數(shù)據(jù)標(biāo)簽、圖例、網(wǎng)格線等,感興趣的朋友一起看看吧2023-10-10
Python異步在非阻塞子進(jìn)程中運(yùn)行命令詳解
這篇文章主要為大家介紹了Python異步在非阻塞子進(jìn)程中運(yùn)行命令詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
python_matplotlib改變橫坐標(biāo)和縱坐標(biāo)上的刻度(ticks)方式
這篇文章主要介紹了python_matplotlib改變橫坐標(biāo)和縱坐標(biāo)上的刻度(ticks)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-05-05
pandas數(shù)據(jù)清洗實(shí)現(xiàn)刪除的項(xiàng)目實(shí)踐
本文主要介紹了pandas數(shù)據(jù)清洗實(shí)現(xiàn)刪除的項(xiàng)目實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
python 實(shí)現(xiàn)一個(gè)反向單位矩陣示例
今天小編就為大家分享一篇python 實(shí)現(xiàn)一個(gè)反向單位矩陣示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11

