gpt4 book ai didi

python - 自定义 Django 模型字段的字段查找功能

转载 作者:太空宇宙 更新时间:2023-11-03 13:52:01 26 4
gpt4 key购买 nike

我有一个自定义模型字段 YearWithSurenessField,它在 python 中由自定义数据类型 YearWithSureness 表示。 YearWithSureness 的构造函数是 YearWithSureness(year='', is_certain=False),其中 year'' 或四位数年份(作为字符串),is_certain 是一个 bool 值,表示我是否确定给定年份是正确的。这种类型的模型字段以 year/is_certain 的形式存储在我的数据库中,例如“2008/True”、“2011/False”、“/False”等

例如,在 Member 模型中,我有一个字段 grad_year = YearWithSurenessField(...) 存储成员(member)的毕业年份以及我是否确定我存储的年份是正确的。

我想做的是使用类似的东西

Member.objects.filter(grad_year__year=2011)

获取毕业年份为“2011/True”或“2011/False”的所有成员的 QuerySet。同样,我希望能够使用类似的东西

Member.objects.filter(grad_year__range=(2000, 2011))

获取 grad_year 在 2000 到 2011 范围内的所有成员的 QuerySet,无论 grad_year.is_certain 是 True 还是 False。

这可能吗?我知道我可以使用 Member.objects.filter(grad_year__contains="2011") 来获得第一个结果,但我希望能够使用 __year。

这里是相关的类,去掉了无关的代码:

class YearWithSureness(object):
def __init__(self, year='', is_certain=False):
# ...

def __str__(self):
return "{year}/{is_certain}".format(year=self.year,
is_certain=self.is_certain)

class YearWithSurenessField(models.Field):
__metaclass__ = models.SubfieldBase

def __init__(self, *args, **kwargs):
# ...

def to_python(self, value):
# ...

def get_prep_value(self, value):
# ...

def get_prep_lookup(self, lookup_type, value):
if lookup_type in ('month', 'day'):
raise TypeError('Lookup type {0} not supported.'.format(lookup_type))
else:
return super(YearWithSurenessField, self).get_prep_lookup(lookup_type, value)

def value_to_string(self, obj):
# ...

最佳答案

这是我发现有用的东西: Creating custom Field Lookups in Django

一种更灵活的方法是编写自定义查询集和自定义管理器。使用 ozan 的代码:

class PersonQuerySet(models.query.QuerySet):
def in_age_range(self, min, max):
return self.filter(age__gte=min, age__lt=max)

class PersonManager(models.Manager):
def get_query_set(self):
return PersonQuerySet(self.model)

def __getattr__(self, name):
return getattr(self.get_query_set(), name)

class Person(models.Model):
age = #...
objects = PersonManager()

这允许您链接自定义查询。所以这两个查询都是有效的:

Person.objects.in_age_range(20,30)
Person.objects.exclude(somefield = some_value).in_age_range(20, 30)

关于python - 自定义 Django 模型字段的字段查找功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5999088/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com