day14 模块

json

# 1.用于多种语言交互  编程语言通用数据

# 内置的 不需要安装 直接导入使用

import json # 导入一个json模块

# dumps loads
# dump load 有持久化的功能
dic = {'1':2}

s = json.dumps(dic)   # 将字典对象转换成字符串
print(type(s))

di = '{"1":2}'
d = json.loads(di)    # 将字符串转换成字典
print(d)
print(type(d))

json.dump({'1':4},open('a','w',encoding='utf-8'))

d = json.load(open('a','r',encoding='utf-8'))
d['1'] = 10
print(d)

json.dump(d,open('a','w',encoding='utf-8'))

d = json.load(open('a','r',encoding='utf-8'))
print(d)

# 总结:
# json.load() #参数文件句柄(r), 将文件中字符串转换成字典
# json.dump() #对象(字典),文件句柄(w) 将字典转换字符串写入到文件中
# json.dumps() #对象(字典) 将字典转换成字符串
# json.loads() #字符串(字典) 将字符串转换成字典
import json
data = {'username':['李华','二愣子'],'sex':'male','age':16}
json_dic2 = json.dumps(data,sort_keys=True,indent=2,separators=(',',':'),ensure_ascii=False)
print(json_dic2)
 
 
pickle
1.pickle 只支持python

dumps loads
dump load 持久化
 
import pickle
print(pickle.dumps({'1':4}))   #将对象转换成类似二进制的东西
print(pickle.loads(b'\x80\x03}q\x00X\x01\x00\x00\x001q\x01K\x04s.'))
将一个堆类似于二进制的东西转换成字典
 
pickle.dump({'2':4},open('b','wb'))
d = pickle.load(open('b','rb'))
print(d)
 
总结:
josn,pickle 对比

loads json里的将字符串转换成字典 pickle 将字节转换成字典
dumps json里的将字典转换成字符串 pickle 将字典转换成字节
load json里的将文件中的字符串转换成字典 pickle 将文件中的字节转换成字典
dump json里的将字典转换字符串写入到文件中,pickle 将字典转换成字节写入到文件中
shelve
 
序列化:
1.文件 + 字典操作
import shelve
f = shelve.open('c',writeback=True)  #创建文件  # writeback = True 回写

f['name'] = 'alex'

f['age'] = 18

print(f['name'],f['age'])

f['name'] = ['alex','wusir']

print(f['name'])

print(f)  # 这样是查看不了字典

for i in f:
    print(i)   #获取到所有的键

print(f.keys())  #keys也不行

for i in f:
    print(f[i])
dump load   咱们不用写,自动帮咱们写的
 
f['name'] = {'2':4}

print(f['name'])

for i in f:
    print(i)
 
注意:以后你们会出现一个问题,咱们对字典的操作内容,有时候写不进去.在open
print(f['name'])

f['name'] = 'wusir'
print(f['name'])   # {'2':4}

f['name'] = [1,2,34]

print(list(f.keys()))
json 最常用,前后端分离的时候数据交互  前后端分离  必回
pickle python 不怎么常用 河南方言 必了解
shelve 建议使用它,它简单 重庆,东北,容易学 必了解


 



 

猜你喜欢

转载自www.cnblogs.com/wodexiaobiji/p/10560706.html