## JSON模块 ```python json语音,是一种有语法规范的字符串,用来存放数据,完成各种语眼的数据交互。 1,就是{},[]的组合,{}存放双列信息(类比为字典),[]存放单列信息(类比为列表)。 2,{}中的key必须是""包裹的字符串。 3,{}的value与[]中支持的值的类型:int|float|str|dict|list|bool|null 序列化:将Python中的对象转换为字符串 dumps:将对象直接序列化成字符串 dump:将对象序列化成字符串存储到文件中 obj = {'name': 'Owen', "age": 18, 'height': 180, "gender": "男"} r1 = json.dumps(obj, ensure_ascii=False) # 取消默认ascii编码,同该文件的编码 utf-8 py3默认,py2规定文件头 print(r1) with open("1.txt","w",encoding="utf-8")as wr json.dump(obj,wf,ensure_ascii=False) 反序列化: json_str ='{"name": "Owen", "age": 18, "height": 180, "gender": "男"}' r2=json.loads(json_str,encoding="utf-8")#默认跟当前文件被解释器执行的编码走。 print(r2,type(r2)) 总结:将对象序列化成json语言时,对对象有什么要求? 将json语言反序列化时,对 ``` ## pickle ```python 为什么有很多序列化和反序列化模块 因为程序中出现的各种各样的对象需要持久化存储,必须要序列化。 序列化:对象转换成字符串 序列化目的:存、传 import pickle obj = {"name": 'Owen', "age": 18, "height": 180, "gender": "男"} # 序列化 r1 = pickle.dumps(obj) print(r1) with open('2.txt', 'wb') as wf: pickle.dump(obj, wf) # 反序列化 with open('2.txt', 'rb') as rf: data = rf.read() o1 = pickle.loads(data) print(o1, type(o1)) rf.seek(0, 0) # 游标移到开头出现读 o2 = pickle.load(rf) print(o2, type(o2)) pickle将对象序列化成二进制字符串。所以,它可以序列化任意对象。 ``` ## hashlib ```python 特点:不可逆的加密方式md5 解密:只能碰撞解密 加密对象:用于传输数据(字符串类型) 为什么不需要解密:多用于密码验证,不需要解密获取。通过登录密码对后台保存的密码进行碰撞,匹配成功即可。 加密步骤: 1,获取加密对象:lock_obj=hashlib.md5() 2,添加加密数据:lock_obj.update(b"") 3,获取加密结果:lock_obj.hexdigest() lock = hashlib.md5(b'...') lock.update(b'...') # ... lock.update(b'...') res = lock.hexdigest() print(res) #加盐加密 1,原数据过于简单,通过复杂的盐也可以提高解密难度 2,即使碰撞成功,也不能识别有效数据与盐。 lock_obj = hashlib.md5() lock_obj.update(b'qianyan') lock_obj.update(b'123') lock_obj.update(b'houyan') res = lock_obj.hexdigest() print(res) # 了了解:其他算法加密 lock_obj = hashlib.sha3_256(b'1') print(lock_obj.hexdigest()) lock_obj = hashlib.sha3_512(b'1') print(lock_obj.hexdigest()) ``` ## hmac ```python import hmac # hmac.new(arg) # 必须提供一个参数 cipher = hmac.new('加密的数据'.encode('utf-8')) print(cipher.hexdigest()) cipher = hmac.new('前盐'.encode('utf-8')) cipher.update('加密的数据'.encode('utf-8')) print(cipher.hexdigest()) cipher = hmac.new('加密的数据'.encode('utf-8')) cipher.update('后盐'.encode('utf-8')) print(cipher.hexdigest()) cipher = hmac.new('前盐'.encode('utf-8')) cipher.update('加密的数据'.encode('utf-8')) cipher.update('后盐'.encode('utf-8')) print(cipher.hexdigest()) ``` ## shutil ```python #基于路径的文件复制: shutil.copyfile("source_file","target_file") #基于流的文件复制: with open("source_file","rb") as r,('target_file', 'wb') as w: shutil.copyfileobj(r,w) #递归删除目标目录 shutil.rmtree("target_folder") #文件移动 shutil.move("oldfile","newfile") #文件压缩 file_name:被压缩后形成的文件名 format:压缩的格式 archive_path:要被压缩的文件夹路径 shutil.make_archive('file_name', 'format', 'archive_path') # 文件夹解压 unpack_file:被解压文件 unpack_name:解压后的名字 format解压格式 shutil.unpack_archive('unpack_file', 'unpack_name', 'format') ``` ## shelve ```python # 将序列化文件操作dump与load进行封装 shv_dic = shelve.open("target_file") # 注:writeback允许序列化的可变类型,可以直接修改值 # 序列化:存 shv_dic['key1'] = 'value1' shv_dic['key2'] = 'value2' # 文件这样的释放 shv_dic.close() shv_dic = shelve.open("target_file", writeback=True) # 存 可变类型值 shv_dic['info'] = ['原数据'] # 取 可变类型值,并操作可变类型 # 将内容从文件中取出,在内存中添加, 如果操作文件有writeback=True,会将内存操作记录实时同步到文件 shv_dic['info'].append('新数据') # 反序列化:取 print(shv_dic['info']) # ['原数据', '新数据'] shv_dic.close() ```