У меня есть следующий код:
exercises = Exercise.objects.filter(teacher=request.user.id).values('id', 'question', 'ans1', 'ans2', 'ans3', 'correct', 'unit', 'resol', 'theme', 'img')
Это отлично работает, но «тема» — это поле «многие ко многим», формат возвращает { ..., theme: value }
вместо { ..., theme: [value1, value2] }
Что я должен реализовать, чтобы получить желаемый формат?
И как я мог это сделать?
Сделал это, выполнив следующие действия:
try:
exercises = Exercise.objects.filter(teacher=request.user.id)
ids = exercises.values_list('id', flat=True)
reloaded_qs = Exercise.objects.all()
reloaded_qs.query = pickle.loads(pickle.dumps(ids.query))
exercise_serializer = ExerciseSerializer(exercises, many=True)
if exercise_serializer.is_valid:
for val, q in enumerate(reloaded_qs):
exercise_serializer.data[val].update(q)
except BaseException as e:
return JsonResponse({ 'v': False, 'm': str(e) }, safe=False)
return JsonResponse(exercise_serializer.data, safe=False)
Я бы использовал сериализатор для этого. Если вы используете
values
, django выполнит левое соединение, которое вернет одну строку для каждой темы для каждого упражнения.