python - 如何使用模型对象作为 django-filter MultipleChoiceFilter 的选择
问题描述
我正在使用 Django 过滤器,并且我希望其中一个字段 ( supervisor
) 成为ChoiceFilter
选择来自模型的对象的位置。最有效的方法是什么?我尝试关注这篇文章,但无论我改变了什么(目前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
模型中的主管的所有人员。
解决方案
我不是 100% 肯定,但你能试试吗?
[people.objects.get(pk=x[0]) for x in people.objects.all().values_list('supervisor', flat=True).distinct()]
或者
[people.objects.get(id=x[0]) for x in people.objects.all().values_list('supervisor', flat=True).distinct()]
在您提到的链接中,我相信
DatedResource.objects.all().values_list('date', flat=True).distinct())
返回一个字符串数组
在您的代码
people.objects.all().values_list('supervisor', flat=True).distinct()
中将返回一个 int 字符串 - 记录的 ID,因为它是外键
推荐阅读
- machine-learning - 内核 3 的 Pytorch DCGAN 示例
- nginx - 如何在 NGINX 中全局设置 Cache-Control
- reactjs - 反应按钮的 Onclick 事件
- android - Flutter - 带有芯片的输入文本字段
- groovy - 如何在变量中添加带有时间戳的电子邮件?或者有可能吗?(卡塔隆)
- reactjs - NEXTJS、React、socketio、Rasberry Pi、DS18B20 - 如何在反应钩子中显示?
- keycloak - 为什么我无法到达这个 keycloak rest api 端点?
- vba - 如何使用 VBA 将 ms 访问 .mdb 转换为 .accdb
- python - 视频和实时的视频捕获问题
- xmlhttprequest - livewire 视图不向组件发送任何 xhr 请求