可以先生成字典,然后使用 json.dumps()函数将字典转为json
1 生成的json不能输出汉字,只输出utf8原始编码,形如 u\x55..格式,需要在 json.dumps()参数列表指定 ensure_ascii=false
2 indent =1 单行输出 不换行,
indent=2 多行输出如下
{
"证券公司\r>华泰证券": {
"colour": 0,
"count3": 10,
"count4": 0,
"count5": 0,
"url": "证券公司\r>华泰证券=url="
},
字典的Key及字典生成 (处理sqlachemy数据库查询结果)
第一种,字典嵌套时:
这里使用了字典嵌套,即数据库中取出一个列表作为字典的key,然后根据每个key再进行数据库操作,key对应的内容又是一个字典,这个时候,对数据库查询返回结果res操作如下:
listv=[]
for i in res:
listv.append(i[0]) //这里如果不可以直接使用i,因为i在这里只是一个数据集合的key对象,并不是value,直接使用i导致了json.dumps函数失败,因为该 函数不接受object类型作为key。
dic={}.fromkeys(listv)
json.dumps(dic) 输出带有key的json数据,举例如下
{ "证券公司\r>华泰证券": { "colour": 0, "count3": 10, "count4": 0, "count5": 0, "url": "证券公司\r>华泰证券=url=" }, "证券公司\r>投资业务平台": { "colour": 2, "count3": 173, "count4": 527, "count5": 0, "url": "证券公司\r>投资业务平台=url=" }, "证券公司\r>西部证券": { "colour": 0, "count3": 2, "count4": 1, "count5": 0, "url": "证券公司\r>西部证券=url=" }, "证券公司>内蒙BOS": { "colour": 0, "count3": 4, "count4": 0, "count5": 0, "url": "证券公司>内蒙BOS=url=" } }
==============================================================================
第二种:无嵌套字典
listv=[]
for i in res:
listv.append(i) //这里直接使用i,。
dic={}.fromkeys(listv)
json.dumps(dic) 输出没有有key的json数据,举例如下:
[ | |
[ | |
"证券公司>内蒙BOS", | |
2, | |
1372293540, | |
2 | |
], | |
[ | |
"证券公司\r>投资业务平台", | |
4, | |
1372279320, | |
45 | |
], | |
] |