取得类似:
{"id":"evt_ugB6x3K43D16wXCcqbplWAJo","created":1440407501,}
这样的JSON数据,因为要用这个数据做加密算法的效验,又效验的算法传参时必须是Python字符串类型的数据,将JSON转为字符串,双冒号会变成单冒号导致效验通不过。
有什么办法可以把上述JSON数据原封不动(连符号都不动,空格不能有,顺序还不能变)直接转为Python的字符串类型么?
看到@伊藤雄吉的回答,我补充一下
这个方案最好是采用 OrderedDict + json.dumps方案
from collections import OrderedDict
content = OrderedDict();
content['id'] = "evt_ugB6x3K43D16wXCcqbplWAJo"
.....
content['created'] = 1440407501
jcont = json.dump(content);
# {"id":"evt_ugB6x3K43D16wXCcqbplWAJo","created":1440407501}
# type(jcont) #<type 'str'>
这样得出的最终的 dict 从头到尾都是有序的, OrderedDict 其实可以看做是 dict 的一个子类,强行保留了其字典序,但是这样消耗的资源要更多。
jod = json.loads(jcont, object_pairs_hook=OrderedDict);
type(jod) # <type collections.OrderedDict>
这样才是一个完整的保证出入有序的方案。
可以使用内置模块 json
content = {"id": "evt_ugB6x3K43D16wXCcqbplWAJo"}
print content #{'id': 'evt_ugB6x3K43D16wXCcqbplWAJo'}
import json
print json.dumps(content) #{"id": "evt_ugB6x3K43D16wXCcqbplWAJo"}
print type(json.dumps(content)) #<type 'str'>
感谢评论中@chaser 的提醒,如果需要对字典中顺序有要求的话,使用OrderDict即可