python从json解压缩一个字典

时间:2014-05-28 14:16:38

标签: javascript python json dictionary turbogears2

我一直在寻找,但我找不到答案,我的猜测是我的问题定义不是很好,所以我希望得到一些指导

我使用的是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转换为嵌套字典(或其他内容)? 感谢

2 个答案:

答案 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提供的控制器,这尤其有用。