170 похожих чатов

Есть фласковская ручка для POST-запроса. Ей в body может быть

передан один из двух параметров — username или email. Я использую werkzeug-овский парсер. Мне нужно найти пользователя в БД по полученным в body данным: или по мылу, или по email. Если ничего не найдено, надо получить None.
post_args = {
'email': fields.String(missing=None),
'username': fields.String(missing=None),
}
Любой аргумент из парсера может быть None. И у пользователей может не быть email или username (но не обоих сразу). Поэтому я не могу сразу передать аргументы в Алхимию, а собираю словарь аргументов для запроса. Если этого не сделать, мы получим первого юзера, где email или username отсутствет, а не то, что запрошено на самом деле:
# prevent equal-None filter query
user, query_kwars, = None, {}
email, username = args.get('email'), args.get('username')

# prepare request query
if email:
query_kwars['email'] = email
elif username:
query_kwars['username'] = username

if query_kwars: # if at least one condition exists
user = db.session.query(User) \
.filter_by(**query_kwars) \
.one_or_none()

if user is None: # user was not populated with parsed conditions
....
Как сделать лаконичнее?

#sqlalchemy #werkzeug

1 ответов

12 просмотров

1) query_kwars = {k:args[v] for k in (“email”, “username”) if k in args } 2) как твой, но вместо args.get + if xxx сделать if xxx in args

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Если у очереди установлено x-message-ttl, при получении сообщения из этой очереди, можно узнать остаток времени жизни сообщения?
Сергей
8
Подскажите как мне лучше держать websocket сединение и переодически передавать в него данные? Сначала я сделал так: for _ in 1...1000 { try? await ws.send("test") try...
Mihail Verenich
2
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Anyone knows how to build this widget in Flutter? I have all the assets for round stations and the road, but how can I make the my widget animate between these stations? And h...
Mohammad Zamani
8
Привет, имею проблему с better-sqlite3 модулем. После npm install я делаю ребилд модуля под свою текущую версию ноды с помощью npx electron-rebuild -f -m node_modules/better-s...
Anton Samofal
2
Ты просто гитлеровскую эстетику плохо понимаешь. Он же всё под Цезаря делал. А это как бы запрещённый приём в политике. Пиджаки они зачем все носят? Чтобы показать что они тип...
Ivan Kropotkin
4
Или к тому, что возложить ответственность на команду OTP, это хорошо, а взять её на себя, это не хорошо? )
Юрий Жлоба
7
Карта сайта