一、json.dumps(i):
json中的dumps方法是用来将特定格式的数据进行字符串化的操作
二、json.dump():
和dumps差一个s,功能作用大致上是一样,也是将数据转换成str格式,并包括了将数据写入json文件的一个操作步骤,json.dump(data, file-open,ascii=False),可以包含三个属性,第三个ascii是用来避免出现unicode写入的乱码的;
三、json.load():
load()函数用于从json文件中读取数据,json.load(file-open)即可,这样可以还原在json文件中的原本的数据格式,诸如列表或者字典;file在open的时候最好是注意用encoding=‘utf-8’的编码,这样出来的数据就是原来的数据,而不会出现乱码;
四、json.loads():
loads用来将字符型数据转换成原来的数据格式,诸如列表和字典,就是原本是什么格式就还原成什么格式。
总之,带有s的方法都是不涉及文件操作的,没有带s的方法都是涉及到文件的操作的。记住这个就不会记错了;
import json
# dump, 把 字典, 列表等信息写入json文件
dict = [{"a":1,"b":"hello"}]
with open('a.json','w', encoding='utf-8') as f:
json.dump(dict, f)
# dumps 把字典,列表等类型变成字符串
string = json.dumps(dict)
print(string)
print(type(string)) # str
# load, 导入json文件, 变换成原类型
with open('a.json','r', encoding='utf-8') as f2:
content = json.load(f2)
print(content)
print(type(content)) # list
# loads, 把字符串变换成原类型, 相当于eval()
s = '[{"a": 1, "b": "hello"}]'
row_dict = json.loads(s)
print(row_dict)
print(type(row_dict)) # list