我有模型A和B,其中B的FK为A.
我使用django 1.3,我需要两个django管理过滤器:
1) a.b_set.exists() # (True/False)
2) not a.b_set.filter(some_condition=False).exists() # (True/False)
我怎样才能实现这一目标?可悲的是,我通过谷歌搜索找不到任何解决方案。
答案 0 :(得分:5)
您需要阅读:Custom Filter in Django Admin on Django 1.3 or below
这是我没有经过任何测试的第一次尝试,但你应该看到它的完成方式 -
from django.db import models
from django.contrib.admin.filterspecs import FilterSpec, ChoicesFilterSpec
from django.utils.encoding import smart_unicode
from django.utils.translation import ugettext as _
class BNullSetFilterSpec(FilterSpec):
def __init__(self, f, request, params, model, model_admin):
super(BSetFilterSpec, self).__init__(f, request, params, model, model_admin)
self.links = (
('Yes', {'b__isnull': False}),
('No', {}))
def title(self):
return _('B Set')
# registering the filter
FilterSpec.filter_specs.insert(0, (lambda f: getattr(f, 'empty_bset', False), BNullSetFilterSpec))
答案 1 :(得分:1)
@ptrck提到的是对的。你不能切换到1.4吗?
在这种情况下,如在the doc中描述的那样,无需更改查找,执行类似的操作(对于第一个,然后是相应的第二个):
from django.contrib.admin import BooleanFieldListFilter
class BInA(BooleanFieldListFilter):
def queryset(self, request, queryset):
if self.value() is True:
return queryset.filter(a.b_set.exists())
else:
return queryset.filter(a.b_set.exists() is False)