Python进行JSON格式化输出,字典与字符串转换,以及汉字显示问题

问题分析:
Python下json方法的json在打印查看时,括号和数据都没有展开,查看起来比较困难

解决方案:
使用json.dumps的separators设置,将数据展开格式化打印

解决步骤:
data = json.dumps(data, sort_keys=True, indent=4, separators=(‘, ‘, ‘: ‘))

data={
    "msgBody":{
            "data":
                {
                    "imgType": "",
                    "imgURL": "image url",
                    "imgLike": 0.5
                }
        },
    "msgHead":{
            "Token": "",
            "Code": "",
            "rmsg": "你好",
        }
}

import json
data_1=json.dumps(data, sort_keys=True, indent=4, separators=(',', ':'),ensure_ascii=False)
print(json.dumps(data, sort_keys=True, indent=4, separators=(',', ':')))
打印结果

{
    "msgBody":{
        "data":{
            "imgLike":0.5,
            "imgType":"",
            "imgURL":"image url"
        }
    },
    "msgHead":{
        "Code":"",
        "Token":"",
        "rmsg":"\u4f60\u597d"
    }
}
然而,这里中文显示有些问题

中文显示
https://blog.csdn.net/smj811504083/article/details/51889751

添加ensure_ascii=False 这个参数,就是上面的 data_1

打印结果显示:

 

{
    "msgBody":{
        "data":{
            "imgLike":0.5,
            "imgType":"",
            "imgURL":"image url"
        }
    },
    "msgHead":{
        "Code":"",
        "Token":"",
        "rmsg":"你好"
    }
}
 
1. Key是文本的时候,如果sort_keys是False,则随机打印结果,如果sortkeys为true,则按顺序打印

2. Key是数字,则无论sort_keys为啥,都按顺序打印。

3. Key为文本和数字交加的时候,等同于文本。

>>> print json.dumps({"A": 5, "F": 8, "D": 7, "C": 9 }, sort_keys=False,indent=4, separators=(',', ':'))
{
"A":5,
"C":9,
"D":7,
"F":8
}
>>>
>>> print json.dumps({"A": 5, "F": 8, "D": 7, "C": 9 }, sort_keys=True,indent=4, separators=(',', ':'))
{
"A":5,
"C":9,
"D":7,
"F":8
}
>>>
>>> print json.dumps({"3": 5, "5": 8, "4": 7, "2": 9 }, sort_keys=False,indent=4, separators=(',', ':'))
{
"3":5,
"2":9,
"5":8,
"4":7
}
>>>
>>> print json.dumps({"3": 5, "5": 8, "4": 7, "2": 9 }, sort_keys=True,indent=4, separators=(',', ':'))
{
"2":9,
"3":5,
"4":7,
"5":8
}
>>>
>>> print json.dumps({3: 5, 5: 8, 4: 7, 2: 9 }, sort_keys=False,indent=4, separators=(',', ':'))
{
"2":9,
"3":5,
"4":7,
"5":8
}
>>>
>>> print json.dumps({3: 5, 5: 8, 4: 7, 2: 9 }, sort_keys=True,indent=4, separators=(',', ':'))
{
"2":9,
"3":5,
"4":7,
"5":8
}
>>>

 

 

 

我们来对这几个参数进行下解释: 
sort_keys:是否按照字典排序(a-z)输出,True代表是,False代表否。 
indent=4:设置缩进格数,一般由于Linux的习惯,这里会设置为4。 
separators:设置分隔符,在dic = {'a': 1, 'b': 2, 'c': 3}这行代码里可以看到冒号和逗号后面都带了个空格,这也是因为Python的默认格式也是如此,如果不想后面带有空格输出,那就可以设置成separators=(',', ':'),如果想保持原样,可以写成separators=(', ', ': ')
ensure_ascii=False :是否显示ascii这个码,默认是ture,改为False 即可


1、json.dumps()和json.loads()是json格式处理函数(可以这么理解,json是字符串)
(1)json.dumps()函数是将一个Python数据类型列表进行json格式的编码(可以这么理解,json.dumps()函数是将字典转化为字符串)
(2)json.loads()函数是将json格式数据转换为字典(可以这么理解,json.loads()函数是将字符串转化为字典)
"""
import json
json_str = '{"code":"1000","msg":"请求成功","typeId":null,"adTitle":null,"adContent":null,"adImg":null,"adLink":null,"adPosition":null,"status":null,"remark":null}'
#print(type(json_str))
#print(json_str)
#data = json.loads(json_str)
#print(data)
#print(type(data))
#new_json = json.dumps(json.loads(json_str),indent = 4,ensure_ascii=False,separators=(',', ':'))
#print(new_json)
#print(type(new_json))
#print(json.loads(new_json))

 

posted on 2020-10-28 11:11  sunny_2016  阅读(1019)  评论(0编辑  收藏  举报

导航