如何将输出变成 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}}
!!如果数据与用户输入相关,这是非常危险的,因为他们可以轻松地将可运行代码插入您的页面。谨慎使用!!
代码:::
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}}
!!如果数据与用户输入相关,这是非常危险的,因为他们可以轻松地将可运行代码插入您的页面。谨慎使用!!