python - 使用嵌套字典和列表在python中创建一个json对象
问题描述
我正在尝试在 python 中创建以下有效负载以发出 POST 请求。以下行来自我浏览器中的 REST 客户端,并创建了我想要的结果,我知道它可以工作。
(URLencoded 表单数据) features=[{"attributes":{"POINT_NAME":"tpoint","EASTING":"338250","NORTHING":"342300","CREATION_DATE":"16/12/2020", },"几何":{"x":338250,"y":342300}}]&f=json
到目前为止,我做了很多尝试,最接近的是以下几种:
import json
import requests
#Create inner dictionary
data_dictionary = {}
data_dictionary['attributes'] = {"POINT_NAME" : "tpoint", "EASTING" : "338250", "NORTHING" : "342300", "CREATION_DATE" : "16/12/2020"}
data_dictionary['geometry'] ={"x" : 338250, "y" : 342300}
data_list = [data_dictionary]
payload = {"features": data_list , "f" : "json"}
r = request.post(API_ENDPOINT_POINT, data = payload)
r.text
有效载荷输出为:{'features': [{'attributes': {'POINT_NAME': 'tpoint', 'EASTING': '338250', 'NORTHING': '342300','CREATION_DATE': '16/12/2020' '},'geometry': {'x': 338250, 'y': 342300}}], 'f': 'json'},但是当我提出请求时,我得到:'{"error":{"code ":500,"message":"无法完成操作。","details":["解析器错误:无法识别某些参数。"]}}'
任何想法都会有所帮助,我被卡住了。
谢谢
解决方案
从评论中复制答案:尝试使用有效负载作为
payload = {"features": json.dumps(data_list) , "f" : "json"}
推荐阅读
- javascript - Google表格数据移动器脚本不一致的问题
- c++ - 如何使 std::regex 匹配 Utf8
- sql-server - 在 SQL Server 上列出等待及其类别
- reactjs - 无法使用 ReactJS 在 OpenLayers 中的两个位置之间绘制默认线
- javascript - 更新:根据 x 轴上的滑块日期更改图表
- java - 启动 Activity 时出现 Google Maps API 密钥错误
- javascript - 使用 javascript 和 vue 映射不同类型的数据
- python - 动态公开对象属性
- r - R中样本大小的多重比较调整
- django - 用户注销时如何触发django函数