Форум программистов, компьютерный форум, киберфорум
Python: Django
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 08.10.2021
Сообщений: 25

Множественные get запросы Django

12.11.2022, 16:08. Показов 1142. Ответов 3

Студворк — интернет-сервис помощи студентам
Учусь Django, создавая интернет-магазин. Столкнулся с проблемой обработки множественных запросов. В общем нужно оформить несколько запросов. Вот код, после него поясню, что да как.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
class Shop(ListView):
    model = Product
    template_name = 'app/shop.html'
    context_object_name = 'shop'
    paginate_by = 9
 
    def get_context_data(self, **kwargs):
        context = super().get_context_data(**kwargs)
        context['price'] = set((x for x in Product.objects.values_list('price', flat=True)))
        return context
 
    def get_queryset(self):
        if self.request.GET.get('find'):
            return Product.objects.filter(draft=False, name__icontains=self.request.GET.get('find'))
        else:
            return Product.objects.filter(draft=False)
В данном коде я в тупую прописал метод общего поиска товаров в функции get_queryset. Конечно, я могу начать писать IF'ами, но это же бред. Таким способом можно, конечно, если упороться, но тогда будет поиск только по одному запросу. Все остальные запросы уже будут проигнорированы. А мне нужно одновременно выбрать, например, и цвет, и размер (например ./?color=red&size=XL). Или же, так как у меня поиск по __icontains, написать в поле поиска "футболка", чтобы появились все товары, содержащие это слово, и далее выбрать бренд, цвет, размер. В итоге должно получиться ./?find=футболка&brand=adik&color=black&si ze=XL. Еще, желательно, сделать такие запросы, которые содержат несколько параметров. Например: ./?find=футболка&brand=adik,puma&color=bla ck&size=XL&price=5000-10000,10001-15000. Надеюсь на помощь, ибо не смог найти инфу ни у нас, ни в англоязычном Интернете.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.11.2022, 16:08
Ответы с готовыми решениями:

POST запросы в Django
Добрый вечер. Появилась проблема, надеюсь на ваши подсказки:) Django. Создал модель, форму, вьюху, все обрабатывается и записывается в...

Как реализовать права доступа на запросы над "серверами"? django rest framework
Здравствуйте. У меня такая задача. Использую django rest framework в качестве сервера для приложения (клиент серверное приложение). Суть...

Множественные запросы к БД
Подскажет можно ли выполнить запрос к БД. Находящихся в sql файл. Просто у меня очень много запросов к БД а записывать их в код программы...

3
60 / 44 / 18
Регистрация: 05.03.2019
Сообщений: 313
13.11.2022, 19:18
django-filter тебе в помощь
1
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5972 / 3734 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
18.11.2022, 17:12
Лучший ответ Сообщение было отмечено ManeChelMain как решение

Решение

Фильтры могут быть вложенными

Python
1
2
3
4
qs = Product.objects.filter(draft=False)
if 'find' in request.GET:
    # сгеренит WHERE draft = false and name ILIKE '%?%'
    qs = qs.filter(name__icontains=request.GET.get('find'))
Добавлено через 2 минуты
Python
1
2
3
4
5
6
if 'find' in request.GET:
    qs = qs.filter(name__icontains=request.GET.get('find'))
if 'size' in request.GET:
    qs = qs.filter(size=request.GET.get('size'))
if 'brand' in request.GET:
    qs = qs.filter(brand__in=request.GET.get('brand').split(','))
0
155 / 120 / 38
Регистрация: 12.12.2013
Сообщений: 374
19.11.2022, 11:02
Сделай свой менеджер, например finder. В нем определи маппинг всего того, что тебе нужно искать в БД. Создай или переопредели какой-нить метод в менеджере для извлечения данных из request. Далее во вьюхе будешь использовать так вместо objects:
Python
1
Product.finder.get(request)
В маппинге заложи все поля по типу
Python
1
{'name__icontains': None}
. О вариациях здесь надо подумать.
Потом используй dict8 для объединения и фильтрацию с удалением None. В
Python
1
Product.objects.filter(**my_mapped_request)
распаковываешь обработанный и готовый к использованию маппер.
Вроде все. Не знаю, заработает такая схема или нет, пробуй. Ну это если такой гемор кажется лучшим по сравнению со стандартными и понятными if'ами.
ЗЫ: 2all сильно меня за такой пример не навозьте, я пока только учу джангу.

Добавлено через 2 часа 8 минут
Также можно почитать рецепт "Filtering object lists" из книги "Django 3 Web Development Cookbook". Там тоже есть вариант фильтрации.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.11.2022, 11:02
Помогаю со студенческими работами здесь

Множественные запросы на сервер
Уважаемые специалисты и знатоки Windows XP! У меня возникли проблемы с посещением своего сайта. Сервер хостинг компании (ХП) блокирует...

Множественные sql запросы
Здравствуйте. Возможно ли осуществить множественный sql запрос по типу (как вариант): $result = ibase_query ( "INSERT INTO...

Множественные запросы MYSQL
Здравствуйте, форумчане! Есть проект в котором, средствами MySql.Data.dll, загружаются данные из множества файлов в базу данных. В...

Множественные запросы в MySQL
Нужно изменить значение поля в базе данных, для этого написана процедура. Сначала вызывается процедура, а потом выбирается...

psycopg2 + PostgreSQL множественные запросы
Доброго времени суток! Лезу посредством Python в БД. Нужно, образно говоря, послать много-много запросов с проверкой на наличие в базе...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru