在django中自定义字段Field详解
作者:huangyali_python 时间:2023-08-02 19:35:53
Django的Field类中方法有:
to_python() # 把数据库数据转成python数据
from_db_value() # 把数据库数据转成python数据
get_pre_value() # 把python数据压缩准备存入数据库
get_db_pre_value() # 把压缩好的数据转成数据库查询集
get_prep_lookup() # 指定过滤的条件
value_to_string() # 数据序列化
如果创建的Field比字符串,日期,整数等更复杂的数据结构,可能需要重写to_python 和from_db_value()方法(Django提供的一个SubfileBase元类,他在赋值时总是调用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
把数据库数据转化成python数据
现在主要是from_db_value 方法 把数据库数据转化成python数据
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):
"""数据库数据转成python数据"""
if value is None:
value=[]
return value
if isinstance(value,list):
return value
return ast.literal_eval(value)
def to_python(self, value):
"""从数据库中读取的数据转成python
eval(value)读取value原来的类型
ast模块就是帮助Python应用来处理抽象的语法解析的。
而该模块下的literal_eval()函数:
则会判断需要计算的内容计算后是不是合法的python类型,
如果是则进行运算,否则就不进行运算。
"""
if not value:
value = []
if isinstance(value, list):
return value
return ast.literal_eval(value)
def get_prep_value(self, value):
"""
把python数据压缩后保存到数据库
或者说把python对象转化成查询值
返回值是个字符串
:param value:
:return:
"""
if value is None:
return value
return str(value)
# def get_db_prep_value(self, value, connection, prepared=False):
# """把查询集数据转化成数据库值 一般不需要重写 只需要覆盖"""
# 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):
"""转换字段数据以进行序列化
Field._get_val_from_obj(obj) 是获取值序列化的最佳方式
"""
value = self._get_val_from_obj(obj)
return self.get_db_prep_value(value)
来源:https://blog.csdn.net/huangyali_python/article/details/79511344
标签:django,自定义,Field
0
投稿
猜你喜欢
Python四大金刚之字典详解
2022-02-22 23:11:20
Yolov5训练意外中断后如何接续训练详解
2022-05-14 00:16:51
jsp自定义标签之ifelse与遍历自定义标签示例
2023-06-25 21:09:34
Python图像运算之图像灰度线性变换详解
2022-06-10 15:12:28
一文弄懂MySQL索引创建原则
2024-01-14 07:38:25
js实现(层,表格)元素圆角的函数
2008-01-01 16:40:00
修改MySQL数据库中表和表中字段的编码方式的方法
2024-01-26 22:23:54
Python基于内置函数type创建新类型
2023-11-18 10:00:29
如何使用pyinstaller打包多个和单个python文件详解
2023-03-30 10:48:26
NumPy 与 Python 内置列表计算标准差区别详析
2023-08-28 20:01:19
Python中Selenium上传文件的几种方式
2022-08-13 04:10:40
在IE8中继续使用滤镜及IE8的一些CSS扩展属性
2009-02-21 11:18:00
web程序员的思考
2009-08-04 13:10:00
使用Python中Tkinter模块的Treeview 组件显示ini文件操作
2022-05-23 03:45:38
python GUI库图形界面开发之PyQt5不规则窗口实现与显示GIF动画的详细方法与实例
2023-09-20 17:59:32
Django前端BootCSS实现分页的方法
2023-12-21 01:45:34
Flask框架实现的前端RSA加密与后端Python解密功能详解
2021-07-26 16:28:13
详解CSS的优先权
2008-05-11 18:57:00
mysql分表的3种方法
2011-01-29 16:50:00
mybatis plus实体类中字段映射mysql中的json格式方式
2024-01-22 16:11:37