나는 아티스트와 그림으로 된 데이터베이스를 가지고 있으며 아티스트 이름과 그림 제목을 기반으로 쿼리하고 싶다. 제목은 json 파일에 있습니다 (아티스트 이름은 아약스에서 나옵니다). 그래서 루프를 시도했습니다. 내가 필요 같은여러 개의 필터가있는 장고 데이터베이스 쿼리는 어떻게 작성합니까?
def rest(request):
data = json.loads(request.body)
artistname = data['artiste']
with open('/static/top_paintings.json', 'r') as fb:
top_paintings_dict = json.load(fb)
response_data = []
for painting in top_paintings_dict[artist_name]:
filterargs = {'artist__contains': artistname, 'title__contains': painting}
response_data.append(serializers.serialize('json', Art.objects.filter(**filterargs)))
return HttpResponse(json.dumps(response_data), content_type="application/json")
그것은 누군가를 위해 좋은하지 않습니다 그냥 못생긴 더블 직렬화 된 JSON 데이터를 개체의 목록을 반환하지 않습니다.
["[{\"fields\": {\"artist\": \"Leonardo da Vinci\", \"link\": \"https://trove2.storage.googleapis.com/leonardo-da-vinci/the-madonna-of-the-carnation.jpg\", \"title\": \"The Madonna of the Carnation\"}, \"model\": \"serve.art\", \"pk\": 63091}]",
이 처리기는 내가 아티스트에 대해 가지고있는 모든 그림을 처리하고 반환합니다.
def rest(request):
data = json.loads(request.body)
artistname = data['artiste']
response_data = serializers.serialize("json", Art.objects.filter(artist__contains=artistname))
return HttpResponse(json.dumps(response_data), content_type="application/json")
아티스트뿐 아니라 제목별로 내 검색어를 필터링하면됩니다.
파이썬의 직렬화 목록을 작성한 다음 해당 목록을 직렬화합니다. json이 직렬화 된 객체 목록 또는 객체 목록 중 하나가되도록 하시겠습니까? –
하나의 개체 목록이 필요합니다. 나는 Art.objects.filter()를 사용하여 하나의 아티스트 이름과 그림 제목 목록을 쿼리 할 수는 없지만 그것이 필요한 것입니다. 한 예술가, 여러 그림. –