Python--json

来源:互联网 发布:米卡有软件 编辑:程序博客网 时间:2024/06/08 13:16

JSON在python中分别由list和dict组成。

这是用于序列化的两个模块:

json: 用于字符串和python数据类型间进行转换pickle: 用于python特有的类型和python的数据类型间进行转换

Json模块提供了四个功能:dumps、dump、loads、load

pickle模块提供了四个功能:dumps、dump、loads、load

json dumps把数据类型转换成字符串 dump把数据类型转换成字符串并存储在文件中 loads把字符串转换成数据类型 load把文件打开从字符串转换成数据类型

json是可以在不同语言之间交换数据的,而pickle只在python之间使用。json只能序列化最基本的数据类型,josn只能把常用的数据类型序列化(列表、字典、列表、字符串、数字、),比如日期格式、类对象!josn就不行了。而pickle可以序列化所有的数据类型,包括类,函数都可以序列化。

事例:

dumps:将python中的 字典 转换为 字符串

import jsontest_dict = {'bigberg': [7600, {1: [['iPhone', 6300], ['Bike', 800], ['shirt', 300]]}]}print(test_dict)print(type(test_dict))#dumps 将数据转换成字符串json_str = json.dumps(test_dict)print(json_str)print(type(json_str))

这里写图片描述

loads: 将 字符串 转换为 字典

new_dict = json.loads(json_str)print(new_dict)print(type(new_dict))

这里写图片描述

dump: 将数据写入json文件中

with open("../config/record.json","w") as f:    json.dump(new_dict,f)    print("加载入文件完成...")

这里写图片描述

load:把文件打开,并把字符串变换为数据类型

with open("../config/record.json",'r') as load_f:    load_dict = json.load(load_f)    print(load_dict)load_dict['smallberg'] = [8200,{1:[['Python',81],['shirt',300]]}]print(load_dict)with open("../config/record.json","w") as dump_f:    json.dump(load_dict,dump_f)

这里写图片描述

原创粉丝点击