django Фильтровать клиентов в определенных группах пользователей

Я хочу отображать клиентов из определенных групп в ListView, не могу понять, как получить набор запросов

class CustomerList(ListView):
  model = Customer
  queryset = Customer.objects.filter(member__groups__name__in=['online', 'whatsapp'])
  template_name = 'customer/customer_list.html'

модели.py

class Customer(models.Model): 
    member = models.ForeignKey(User, verbose_name=_("Customer"), on_delete=models.CASCADE)
    contact = models.ForeignKey(Contact, verbose_name=_("Contact"), on_delete=models.CASCADE, blank=True, null=True)
    ...

Клиенты добавляются в группы следующим образом:

class AddUser(CreateView):
  def post(self, request, *args, **kwargs):
     form = UserForm(request.POST) 
     if form.is_valid(): 
        user = form.save(commit=False)
        group, created = Group.objects.get_or_create(name='online')
        user.groups.add(group)
        user.save()

person Laxmikant    schedule 27.08.2020    source источник
comment
__in требует двух плоских дефисов вместо одного, это исправит?   -  person voodoo-burger    schedule 27.08.2020
comment
@voodoo-burger - извините, там опечатка, но это тоже не сработало   -  person Laxmikant    schedule 27.08.2020
comment
Использование related_name здесь сбивает с толку. Что, если вы удалите его, запустите миграции и используете user__groups__name__in?   -  person voodoo-burger    schedule 27.08.2020
comment
@voodoo-burger - позвольте мне попробовать   -  person Laxmikant    schedule 27.08.2020
comment
Отвечает ли это на ваш вопрос? Django: как фильтровать пользователей, принадлежащих к конкретная группа   -  person voodoo-burger    schedule 27.08.2020
comment
@voodoo-burger - уже пробовал, но безрезультатно! Этот queryset возвращает только пользователей, тогда как я хочу, чтобы весь объект Customer, поскольку в шаблоне будут отображаться некоторые другие поля модели Customer   -  person Laxmikant    schedule 27.08.2020
comment
Хм, если вы используете это внутри Customer.objects.filter(), оно может возвращать только Customer объектов... Если вам нужна дополнительная информация о пользователе, связанном с клиентом, вы можете получить ее с помощью object.customer.x. Это очень сбивает с толку, что вы даете своей модели Customer поле, которое также называется customer.   -  person voodoo-burger    schedule 27.08.2020
comment
хорошо, позвольте мне изменить это, чтобы решить вашу путаницу   -  person Laxmikant    schedule 27.08.2020
comment
Каков результат print(Customer.objects.filter(member__groups__name__in=['online', 'whatsapp']).count())?   -  person JPG    schedule 27.08.2020
comment
@ArakkalAbu - ноль (0). но я уверен, что есть клиенты с online группами. и это тоже не ошибка   -  person Laxmikant    schedule 27.08.2020


Ответы (1)


У меня работает аналогичный код, проверьте, работает ли он у вас -

class ProfessorsList(generic.list.ListView):
  model = Staff
  queryset = Staff.objects.filter(member__groups__name='teaching')

Для нескольких групп вы бы сделали так: (Я думаю, вы уже это делаете...)

Customer.objects.filter(member__groups__name__in=['online', ...])

Если это все еще не работает для вас, попробуйте следующее:

  users = User.objects.filter(groups__name__in=[your_groups])
  queryset = Customer.objects.filter(member__in=users)

Убедитесь, что customers имеет users и users часть your_groups

person trex    schedule 27.08.2020