#django #dictionary #django-queryset
#django #словарь #django-queryset
Вопрос:
У меня есть более двух наборов запросов django, и я объединил их в список, как показано на рисунке ниже.
work_queryset = Work.objects.filter(base_id = q).values('worktype', 'datestart', 'dateend', 'dailyworktime', 'remarks')
holiday_queryset = Holiday.objects.filter(base_id = q).values('holiday_type', 'datestart', 'dateend', 'remarks')
Объединенный список
merged_list = list(chain(work_queryset, holiday_queryset))
вывод
[{'datestart': u'2016-04-11', 'dateend': u'2018-07-21', 'remarks': u'Hello remarks', 'worktype': u'Remote'}, {'remarks': u'New holiday', 'datestart': u'2018-09-22', 'dateend': u'2019-09-22', 'holiday_type': u'Sick leave'}, {'remarks': u'nothing comment', 'datestart': u'2016-04-11', 'dateend': u'2016-07-20', 'holiday_type': u'Summer holiday'}]
Чего я пытаюсь добиться, так это преобразовать merged_list в dictionary, как показано ниже:
[{'work' : [{'datestart': u'2016-04-11', 'dateend': u'2018-07-21', 'remarks': u'Hello remarks', 'worktype': u'Remote'}], 'holiday': [{'remarks': u'New holiday', 'datestart': u'2018-09-22', 'dateend': u'2019-09-22', 'holiday_type': u'Sick leave'}, {'remarks': u'nothing comment', 'datestart': u'2016-04-11', 'dateend': u'2016-07-20', 'holiday_type': u'Summer holiday'}]}]
Как я могу этого добиться?
Ответ №1:
Я не понимаю, для чего нужен список out в том, чего вы пытаетесь достичь.
Мне кажется, вы просто хотите
{
'work': list(work_queryset),
'holiday': list(holiday_queryset)
}