Django получение первичного ключа с помощью ответа JSON
Как отправить первичный ключ каждого объекта в JSON-ответе? Я отправляю json-ответ для изменения таблицы на основе состояния пользователей. Все работает хорошо, за исключением того, что я не могу получить PK, связанный с каждым пользователем.
В настоящее время он отправляет все значения, кроме PK.
class UserByState(View):
page_limit = 100
def get_paginated_context(self, queryset, page, limit):
if not page: page = 1
if limit:
self.page_limit = limit
paginator = Paginator(queryset, self.page_limit)
page_obj = paginator.get_page(page)
serialized_page = serialize("json", page_obj.object_list)
serialized_page = [obj["fields"] for obj in json.loads(serialized_page)]
return {
"data": serialized_page,
"pagination": {
"page": page,
"limit": limit,
"has_next": page_obj.has_next(),
"has_prev": page_obj.has_previous(),
"total": queryset.count()
}
}
def get(self, request, *args, **kwargs):
user = self.request.user
page = request.GET.get('page')
limit = request.GET.get('limit')
state = request.GET.get('state')
queryset = User.objects.all()
if state and state != "all":
queryset = queryset.filter(state=state)
to_return = self.get_paginated_context(queryset, page, limit)
return JsonResponse(to_return, status = 200)
Я думаю, что это понимание может потерять некоторые значения.
serialized_page = serialize("json", page_obj.object_list)
Когда вы звоните ['fields'] сюда:
serialized_page = [obj["fields"] for obj in json.loads(serialized_page)]
Вы получаете только значения ключа 'fields'. Это похоже на стандартный словарь.
fields = {"first_name": "Dan", "last_name": "ram", "address": "6090 DRAGON WAY", "city": "CREST", "state": "CA", "zipcode": 91912}
Попробуйте это:
serialized_page = serialize("json", page_obj.object_list)
serialized_page = [{**obj["fields"], **{"pk": obj["pk"]}} for obj in json.loads(serialized_page)]