漂亮的打印JSON python

时间:2014-04-01 17:32:37

标签: python json string google-visualization pprint

如果任何对漂亮印刷JSON有所了解的人可以帮助我,我将非常感激!

我希望将复杂的python字符串转换为JSON格式,使用下面的函数将JSON字符串移动到文件中:

with open('data.txt', 'wt') as out:
    pprint(string, stream=out)

问题是,我认为方括号会出现语法错误,因为这对我来说是一个新主题,我无法弄清楚如何解决这个问题。我需要的JSON格式是这样的:

  {
        cols:[{id: 'Time', "label":"Time","type": "datetime"},
              {id: 'Time', "label":"Latency","type":"number"}],
        rows:[{c: [{v: %s}, {v: %s}]},
              {c: [{v: %s}, {v: %s}]}, 
              {c: [{v: %s}, {v: %s}]},
              {c: [{v: %s}, {v: %s}]}
              ]
    }

我遵循Google Visualization API,您可能比较熟悉,但我需要动态图表。上面的代码是API创建图形所需的格式,因此我正在弄清楚如何将我的数据从MYSQL转换为这种格式,因此图形可以读取和显示。我想到的方法是定期更新包含所需JSON格式的文件,这就是%s存在的原因,但是MartijnPeters认为这是无效的。

有没有人知道我能做到的最简单的方法,或者你能指出我可以帮助的任何材料吗?谢谢!!

1 个答案:

答案 0 :(得分:45)

您正在编写 Python表示,而不是JSON。

使用json.dump() function将漂亮打印的JSON直接写入您的文件:

with open('data.txt', 'wt') as out:
    res = json.dump(obj, out, sort_keys=True, indent=4, separators=(',', ': '))