python – 自定义Django模型字段的字段查找功能
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python – 自定义Django模型字段的字段查找功能,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2237字,纯文字阅读大概需要4分钟。
内容图文
![python – 自定义Django模型字段的字段查找功能](/upload/InfoBanner/zyjiaocheng/730/b7b7abdb43c4409394ffb183d1761bee.jpg)
我有一个自定义模型字段YearWithSurenessField,它由python中的自定义数据类型YearWithSureness表示. YearWithSureness的构造函数是YearWithSureness(year =”,is_certain = False),其中year是”或者是四位数年份(作为字符串),is_certain是一个bool,表示我是否确定给定年份是正确的.此类型的模型字段以年份/ is_certain的形式存储在我的数据库中,例如“2008 / True”,“2011 / False”,“/ False”等
例如,在会员模型中,我有一个字段grad_year = YearWithSurenessField(…),它存储会员的毕业年份以及我是否确定我存储的年份是正确的.
我希望能够做的就是使用类似的东西
Member.objects.filter(grad_year__year=2011)
获取其grad_year为“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
更灵活的方法是编写自定义QuerySet以及自定义管理器.使用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模型字段的字段查找功能全部内容,希望文章能够帮你解决python – 自定义Django模型字段的字段查找功能所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。