Как считать совпадения в разных наборах запросов - PullRequest
0 голосов
/ 17 февраля 2020

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

функция просмотра:

class Search(ListView):

template_name='artdb/searchResult.html'

def get_queryset(self): # override get_queryset() has to have that name...

    q=self.request.GET.get('seastr')
    models=[Person,Activity,Member,Comment]
    fields=[l._meta.fields for l in models]
    res=[]

    for i,j in enumerate(models):
        sq=[Q(**{x.name + "__icontains" : q}) for x in fields[i] if not isinstance(x,ForeignKey)]
        res+=[j.objects.filter(k) or None for k in sq]

    res=[k for k in res if k]

    if q:
        return res
    else:
        return Person.objects.none()  # SELECT ... WHERE headline ILIKE '%Lennon%';

def get_context_data(self,*args,**kwargs):

    #q=self.request.GET.get('seastr')
    context=super().get_context_data(*args,**kwargs)     
    context['member']=Member.objects.all()
    return context

контекстный дикт:

{'page_obj': None, 'view': <artdb.views.Search object at 0x7f415ec88080>, 'is_paginated': False, 'object_list': [<QuerySet [<Person: David Bolander>, <Person: adam something>]>, <QuerySet [<Comment: david bolander comment>]>], 'member': <QuerySet [<Member: 2019-11-21>, <Member: 2020-02-10>]>, 'paginator': None}

мой шаблон:

{% extends "artdb/index.html" %}

{% block sr1 %}
    <ul>
      <a class="btn btn-light btn-outline-success my-2 my-sm-0" role="button" href="{% url 'artdb:search' %}">
        Persons: {{object_list.count}}
      </a>
      <a class="btn btn-light btn-outline-success my-2 my-sm-0" role="button" href="{% url 'artdb:search' %}">
    Activities: {{activity.count}}
      </a>
      <a class="btn btn-light btn-outline-success my-2 my-sm-0" role="button" href="{% url 'artdb:search' %}">
    Members: {{member.count}}
      </a>
      <a class="btn btn-light btn-outline-success my-2 my-sm-0" role="button" href="{% url 'artdb:search' %}">
    Comments: {{comment.count}}
      </a>
      <br></br>
</ul>
{% endblock sr1 %

Как видно из шаблона Я хочу посчитать совпадения в теге <a>, но наборы запросов составлены в виде списков списков в контекстном словаре. Например, член может быть посчитан, потому что он был добавлен позже, и его нет в списке списков. как мне решить это?

1 Ответ

0 голосов
/ 17 февраля 2020

хорошо, я нашел решение для этого. Я снова вставляю object_list в контекстный текст:

def get_context_data(self,*args,**kwargs):

        context=super().get_context_data(*args,**kwargs)

        c=context['object_list']
        cname=[l.model.__name__ for l in c]

        for l in zip(cname,c):
            context[l[0].lower()]=l[1]

        return context

это не самое элегантное решение, и если у кого-то есть другое решение, поделитесь им.

...