Tornadoを使用してPythonでJSONオブジェクトを出力する方法についてのアイデア。良い例、チュートリアル、ライブラリ、またはJSONPオブジェクトを出力する1行のコード。
質問する
11794 次
2 に答える
23
Tornadoは、 Python2.6以降またはPython2.5でtornado.escape.json_encode
ラップするだけのを提供します。使い方は簡単です。json
simplejson
from tornado.escape import json_encode
obj = {
'foo': 'bar',
'1': 2,
'false': True
}
self.write(json_encode(obj))
出力:
{"1": 2, "foo": "bar", "false": true}
JSONP応答の場合:
callback = self.get_argument('callback')
jsonp = "{jsfunc}({json});".format(jsfunc=callback,
json=json_encode(obj))
self.set_header('Content-Type', 'application/javascript')
self.write(jsonp)
于 2012-07-27T23:49:53.193 に答える
1
その方法でjson objを返すことができます
import json
class GetYearsHandler(tornado.web.RequestHandler):
def get(self):
try:
response = get_years(self.get_argument("dataset_id"))
result = {'status':'success', 'response': response}
kk = tornado.escape.json_encode(result)
kk = wrap_callback(self, kk)
self.write(kk)
except Exception, e:
print >> sys.stderr, "Error occured:\n%s" % format_exc()
self.write(json.dumps({'status': 'fail', 'error': "Error occured:\n%s" % format_exc()}))
def get_years (dataset_id):
dates=[]
years=[]
conn = condb()
cur = conn.cursor()
data = {'dataset_id':dataset_id}
cur.execute("SELECT layers.start_time FROM layers, datasets WHERE (layers.dataset_id=datasets.id) AND (datasets.business_id=%(dataset_id)s)",data)
for row in cur.fetchall():
dates.append(row[0])
date=""
for date in dates:
year = int(date.year)
if not year in years:
years.append(year)
conn.close()
years.sort()
return years
クラスを登録する
def main(db_fn=None):
tornado.options.parse_command_line()
application = tornado.web.Application([
(r"/get_datasets", GetDatasetsHandler),
(r"/get_years", GetYearsHandler),
)
conn - データベース接続です
于 2012-07-27T19:53:59.247 に答える