我使用的是Django过滤器,我希望其中一个字段(supervisor
)是一个ChoiceFilter
,其中的选项是来自模型的对象。最有效的方法是什么?我试着跟随this post,但无论我做了什么更改,都会不断出现错误(目前cannot unpack non-iterable int object
)
# models.py
class people(models.Model):
namelast = models.CharField(max_length=100, verbose_name='Last Name')
namefirst = models.CharField(max_length=100, verbose_name='First Name')
supervisor = models.ForeignKey('self', blank=True, null=True, on_delete=models.SET_NULL, verbose_name='Supervisor')
def __str__(self):
return "%s %s" % (self.namefirst, self.namelast)
# filters.py
class office_filter(django_filters.FilterSet):
supervisor = django_filters.ChoiceFilter(choices=[], lookup_expr='icontains', label='Supervisor')
# other fields
class Meta:
model = people
fields = ['namelast', 'namefirst', 'supervisor']
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
try:
self.filters['supervisor'].extra['choices'] = [x for x in
people.objects.all().values_list('supervisor', flat=True).distinct()]
except (KeyError, AttributeError):
pass
我们的目标是使supervisor
字段成为people
模型中被指定为主管的所有添加人员的一个好菜单
我不是百分之百肯定,但你能试试吗
或
在你提到的链接中,我相信
DatedResource.objects.all().values_list('date', flat=True).distinct())
返回字符串的数组在代码中
people.objects.all().values_list('supervisor', flat=True).distinct()
将返回一个int字符串-记录的ID,因为它是外键Ananya's answer帮助我正确地理解了该语句返回的内容,但是在考虑了错误以及选择列表通常是如何构造的之后,我意识到我需要它来返回元组(而不仅仅是值)。以下是最终有效的相关代码:
重要的部分是:
(people.objects.get(pk=x).id, people.objects.get(pk=x))
,而不仅仅是people.objects.get(pk=x)
还必须删除筛选器字段中的
lookup_expr
相关问题 更多 >
编程相关推荐