如何将输出变成 json 格式?

How to get the output into a json format?

代码:::

from bottle import route, request, response, template,run
import petl as etl
@route('/loc')
def abc():
    response.headers['Access-Control-Allow-Origin']='*'
    response.headers['Content-type']='application/json'
    post = request.query.postcode
    locationTable = etl.fromcsv('clinic_locations.csv')
    abcd = etl.search(locationTable, 'Postcode', post)
    return template('{{postcode}}',postcode=abcd)

这是 csv 文件,我想在 json 中得到结果,但我不知道该怎么做,因为我对 petl 和 bottle 框架还很陌生 当用户在浏览器上输入 url 例如 "localhost:8080/loc?postcode=4700" 时,它将 return 有关该邮政编码的数据,但采用 csv 格式,但我想获得 json 格式的输出所以我可以使用这些数据在地图上找到地址 谁能帮我看看结果

示例:在 运行 localhost by bottle framework 之后,我希望在浏览器上的输出是:

已更新 但我得到的是:

像这样将table转换为JSON,需要使用json模块。这是通过查看 petl 模块源代码创建的。

from bottle import route, request, response, template,run
import petl as etl
import json
@route('/loc')
def abc():
    response.headers['Access-Control-Allow-Origin']='*'
    response.headers['Content-type']='application/json'
    post = request.query.postcode
    locationTable = etl.fromcsv('clinic_locations.csv')
    abcd = etl.search(locationTable, 'Postcode', post)
    abcd = json.JSONEncoder().encode(list(etl.dicts(abcd))) #Here's where the magic happens.
    return abcd

如果您最终使用此答案,请确保您的数据库已过滤掉所有 <script> 标签,否则恶意用户可以将 JavaScript 插入您的数据库并使您的 API 端点运行 任意 JavaScript 也称为 XSS 攻击。

所以有两件事,你应该使用 json.dumps 作为你的输出。而 bottle 总是会逃避输出以确保安全。要绕过这个,您应该加载一个调用变量的模板。然后在模板内部,像这样访问变量: {{!variable_name}}

!!如果数据与用户输入相关,这是非常危险的,因为他们可以轻松地将可运行代码插入您的页面。谨慎使用!!