Создание JSON с Python CGI возвращает только одну строку - PullRequest
0 голосов
/ 10 июня 2018

Я пытаюсь создать JSON из моего SQL-запроса с помощью Python CGI, однако он возвращает только одну строку в моей таблице, я не уверен, что я делаю неправильно.Вероятно, это связано с моим объявлением списка, но я не уверен, как это исправить

#!/usr/bin/env python3

import cgi
import cgitb
import sys
import json
import cx_Oracle
cgitb.enable()


fs = cgi.FieldStorage()

with open("../../password.txt", 'r') as pwf:
pw=pwf.read().strip()



imagequery = """ 
SELECT PLACENAME_ID, COMMENT FROM PLACENAMES
"""
conn = cx_Oracle.connect(dsn="gen", user="7", password=pw)
c = conn.cursor()
c.execute(imagequery)

place_id = []
comment = []
for row in c:
    place_id =row[0]
    comment = row[1]



result = {}
result['place_id'] = place_id
result['comment'] = comment

sys.stdout.write("Content-Type: application/json")
sys.stdout.write("\n")
sys.stdout.write("\n")



sys.stdout.write(json.dumps(result,indent=1))
sys.stdout.write("\n")

sys.stdout.close()

Результат

{
 "place_id": 5326,
"comment": "Graveyard"
}

1 Ответ

0 голосов
/ 10 июня 2018

Создать словарь из каждой записи и добавить его в массив.Ваш JSON будет содержать массив со всеми записями базы данных.

places=[]
for row in c:
    place = {}
    place['place_id'] = row[0]
    place['comment'] = row[1]
    places.append(place)



result = {}
result['places'] = places
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...