我一直在寻找,但我找不到答案,我的猜测是我的问题定义不是很好,所以我希望得到一些指导
我使用的是turbogears2.2 我通过$ .post()从客户端视图发送JavaScript对象, 在服务器上,我收到这个对象(如kw):
{'phones[1][surname]': u'sym', 'phones[2][name]': u'', 'phones[1][phone]': u'5498498', 'phones[0][phone]': u'0564', 'phones[1][name]': u'jhon', 'phones[0][surname]': u'cat', 'phones[2][phone]': u'', 'phones[0][name]': u'bob'}
我从一个包含3列的表中发送数据
在我的服务器上,我试图将每行的数据分开,但我在这里有点丢失。 如何将该字典分成不同的数据行?
否则
import json
json.loads(str(kw))
失败
{ValueError}: Expecting property name: line 1 column 2 (char 1)
如何将该dict / object转换为嵌套字典(或其他内容)? 感谢
答案 0 :(得分:0)
感谢您的帮助Martijn Pieters,我以为我发布了JSON,但我不是。
您没有发布JSON;你发布了jQuery为PHP数组功能格式化的application / x-www-form-urlencoded数据。 - Martijn Pieters
这是我的JavaScript,我正在尝试HandsOnTable(jQuery数据网格编辑器)
$("#sendToServer").click(function(){
var tableData = $("#myTable").data('handsontable');
$.post(
URL,
{phones:tableData.getData()},
function(data){
console.log(data)
}
)
})
这并不是JSON,即使我认为它是
无论如何,简单修复:
客户端(JavaScript):
var tableData = $("#myTable").data('handsontable');
var jsonData = JSON.stringify(tableData.getData())
...
$.post(URL,
{phones:jsonData},
...
)
现在在服务器端(Python):
import json
def getPhones(self,**kw):
phones = json.loads(kw['phones'])
...
我将数据作为行的字典,很棒
感谢您的指导
答案 1 :(得分:0)
要发布 JSON ,请勿使用$.post()
。请改用$.ajax()
,并明确设置内容类型:
$.ajax({
url: URL,
type: "POST",
data: JSON.stringify({phone: tableData.getData()}),
contentType: 'application/json; charset=utf-8'
dataType: 'json',
success: function(data) {
console.log(response);
},
});
如果您有一个直接处理JSON的控制器,例如TurboGears Web Services提供的控制器,这尤其有用。