json模块是python内置的库,在使用的时候直接导入就可以。
json模块的操作使用相对较为简单,该模块只有四个方法dump()、load()、dumps()、loads()。
json模块的主要功能是将序列化数据从文件里读取出来或者存入文件。
其中dump()是将数据存入文件中**,load()是用于读取文件**。
而dumps()和loads()是对python对象进行操作。dumps()是将python对象编码成json字符串。loads()是将json字符串解码成python对象。
json字符串 → \rightarrow → python对象
json.dumps()和json.dump()的区别
json.dumps() 是把python对象转换成json对象的一个过程,生成的是字符串。
json.dump() 是把python对象转换成json对象生成一个fp的文件流,和文件相关。
json.loads()和json.load()的区别同上类似,加上s的方法是用来处理字符串类型的,而不加s是用来处理文件类型的。
加s用来处理字符串类型
不加s用来处理文件类型哒。
json.dumps():对数据进行编码,形成json格式的数据
import json
if __name__ == '__main__':
data_dict = {"key2": "value2", "key1": "value", "key3": "value3"}
# 默认转换的json数据是无序的。如果将参数sort_keys改为True,
# 则会根据key值将数据进行排序。
json1 = json.dumps(data_dict, sort_keys=True)
# 默认无序
json2 = json.dumps(data_dict)
print(json1)
print(json2)
# 输出{"key1": "value", "key2": "value2", "key3": "value3"}
# 输出{"key2": "value2", "key1": "value", "key3": "value3"}
json.loads():和dumps相反,loads函数则是将json格式的数据解码,转换为Python字典
import json
if __name__ == '__main__':
data_str = '{"key1": "value1", "key2": "value2", "key3": "value3"}'
data_dict = json.loads(data_str)
print(data_dict)
#输出:{'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}
json.dump()和json.load():与dumps()和loads的功能相似**,只不过dump()和load是处理文件的**
import json
if __name__ == '__main__':
data = '{"key1": "value1", "key2": "value2", "key3": "value3"}'
with open(' data.json', '', encoding='utf-8') as f:
json.dump(data, f)
# 等同于f.write(json.dumps (data))
with open(' data.json', 'r') as f:
infos = json.load(f)
# infos = json.loads (f.read())#和上面的效果一样
j s o n json json模块是用来读写数据的,用法也很简单。