Python里Dict格式的存储: 转为 json 格式进行读写

前言

Python里字典类型(Dict)的数据进行保存的时候可以用借用pickle序列化的方式,

同时pickle序列化可以保存python里复杂的数据模型, 但缺点是无法用本的记事本打开直观的查看数据内容:

import pickle 
def save_obj(obj, name ):
    with open('obj/'+ name + '.pkl', 'wb') as f:
        pickle.dump(obj, f, pickle.HIGHEST_PROTOCOL)

def load_obj(name ):
    with open('obj/' + name + '.pkl', 'rb') as f:
        return pickle.load(f)

而在Python语言中,json数据与dict字典以及对象之间的转化,是必不可少的操作,
所以我们可以考虑转换成json格式,然后再进行读取保存。

Python json 包里的 dump(),load() , dumps(),loads()

  • json.dumps(): 用于将dict类型的数据转成str
import json

dict = {'a': 'wo', 'b': 'zai', 'c': 'zhe', 'd': 'li'}
string = json.dumps(dict)
print(dict)
print(string)
print(type(dict))
print(type(string))

with open(r'C:\Users\zy\Documents\GitHub\python3\searchTest\json.json','w')as f:
    f.write(string)
1 {'a': 'wo', 'b': 'zai', 'c': 'zhe', 'd': 'li'}
2 {"a": "wo", "b": "zai", "c": "zhe", "d": "li"}
3 <class 'dict'>
4 <class 'str'>

如果没有进行转换,则会报错:TypeError: write() argument must be str, not dict

同时这里要注意, 如果dict中有中文,dump()会输出中文的ascil编码,所以需要将默认参数ensure_ascii = False,同时常见还有参数indent控制输出的str字符之间的间隔大小。

friends={"name":"王虎","name1":"张二","name2":"姚晨"}
print(json.dumps(friends,ensure_ascii=False ,indent =3 )) 
  • json.loads():用于将str类型的数据转成dict:
dict = {'a': 'wo', 'b': 'zai', 'c': 'zhe', 'd': 'li'}
dumps = json.dumps(dict)
loads = json.loads(dumps)

print(dict)
print(dumps)
print(loads)

print(type(dict))
print(type(dumps))
print(type(loads))
{'a': 'wo', 'b': 'zai', 'c': 'zhe', 'd': 'li'}
{"a": "wo", "b": "zai", "c": "zhe", "d": "li"}
{'a': 'wo', 'b': 'zai', 'c': 'zhe', 'd': 'li'}
<class 'dict'>
<class 'str'>
<class 'dict'>
  • json.dump() 用于将dict类型的数据转成str,并写入到json文件中 , 相当于f.write(json.dumps())
dict = {'a': 'wo', 'b': 'zai', 'c': 'zhe', 'd': 'li'}
json.dump(dict,open(r'C:\Users\zy\Documents\GitHub\python3\searchTest\json.json','w'))
  • json.load() 用于从json文件中读取数据,相当于f.read(json.loads())
filename = (r'C:\Users\zy\Documents\GitHub\python3\searchTest\json.json')
jsObj = json.load(open(filename))
print(jsObj)
print(type(jsObj))
{'a': 'wo', 'b': 'zai', 'c': 'zhe', 'd': 'li'}
<class 'dict'>
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python中,我们可以使用json模块来读写JSON数据并进行格式化输出。首先,我们可以使用json.load()函数来读取JSON数据并将其转换为Python字典。例如,我们可以使用以下代码读取一个名为example.json的文件并将其转换为字典: ```python import json with open('example.json', 'r') as file: data = json.load(file) print(data) ``` 这将打开example.json文件并将其内容转换为一个字典,并将其打印出来。\[2\] 如果我们想要将Python字典转换为JSON格式进行格式化输出,我们可以使用json.dumps()函数。例如,我们可以使用以下代码将一个名为load_dict字典转换为JSON格式进行格式化输出: ```python import json load_dict = {'one': 1, 'two': {2.1: \['a', 'b'\]}} with open("./format_json.json", 'w') as write_f: write_f.write(json.dumps(load_dict, indent=2, ensure_ascii=False)) with open("./format_json.json", 'r') as load_f: load_dict = json.load(load_f) print(load_dict) ``` 这将把load_dict字典转换为JSON格式并写入到名为format_json.json的文件中。然后,我们再次读取该文件并将其转换为字典,并将其打印出来。\[3\] #### 引用[.reference_title] - *1* [【Python读写JSON格式化输出,让数据更清晰】](https://blog.csdn.net/update7/article/details/129680159)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Python读写JSON 格式化输出](https://blog.csdn.net/update7/article/details/129717519)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [python读写json 格式化输出](https://blog.csdn.net/jacke121/article/details/115438658)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值