模块(二)os hashlib
1.序列化模块
1.1 json 将满足条件的数据结构转化成特殊的字符串,并且可以反序列化转回去
# 两对方法
# 1 dumps() loads() ## 多用于网络传输
d = {"aa":1,"bb":2}
import json
s = json.dumps(d) ## 转储 为str
# 想转回去 用 loads()
d1 = json.loads(s) ## 反序列化
## 第二对方法 dump() load() 只能用作文件转储 而且只能写一行
d = {'aa':'噜啦啦',"bb":22}
with open('j1.json',encoding='utf-8',mode='w') as f1:
json.dump(d,f1,ensure_ascii=False) ## 参数显示中文
with open('j1.json',encoding='utf-8') as f2:
d2 = json.load(f2)
print(d2)
## json 转多条数据到文件中时
import json
dic1 = {'name':'oldboy1'}
dic2 = {'name':'oldboy2'}
dic3 = {'name':'oldboy3'}
l = [dic1,dic2,dic3]
with open('j2.json',encoding='utf-8',mode='a') as f1:
f1.write(json.dumps(l))
with open('j2.json',encoding='utf-8') as f2:
s2 = f2.read()
l2 = json.loads(s2)
1.2 pickle
只限于python内使用
dic1 = {'name':'oldboy1'}
dic2 = {'name':'oldboy2'}
dic3 = {'name':'oldboy3'}
f = open('pick多数据',mode='wb')
pickle.dump(dic1,f)
pickle.dump(dic2,f)
pickle.dump(dic3,f)
f.close()
f = open('pick多数据',mode='rb')
while True:
try:
print(pickle.load(f))
except EOFError:
break
f.close()
## 操作和json大致相同,只是默认转为bytes,所以文件操作的时候要用 二进制b 格式
2 os 操作系统交互
# 和路径相关
## 绝对路径
# t = os.path.abspath('t1.py')
# print(t)
# 切割 成一个两项元组, 前面的所有路径+最后一个路径
# t = os.path.split(__file__)
# print(t)
# ## 父级路径 split切割后的元组 索引 0
# t = os.path.dirname(os.path.abspath('t1.py'))
# print(t)
## __file__绝对路径
# print(__file__)
## 获取文件名 split切割后的元组 索引 1
# t = os.path.basename(__file__)
# print(t)
# 判断路径是否存在
# t= os.path.exists('t1.py')
# print(t)
## 判断是否是绝对路径
# print(os.path.isabs(r'D:\_albertfighting'))
# print(os.path.isabs(r'fightingday_09'))
## 判断是否是文件 或者是路径
print (os.path.isfile('t1.py'))
print(os.path.isdir('t1.py'))
## 拼接 路径
print(os.path.join('a','b'))
## 时间和大小
## os.path.getatime(path) 返回path所指向的文件或者目录的最后访问时间 **
## os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间 **
## os.path.getsize(path) 返回path的大小 ***
## 文件操作
## 获取当前路径下 所有子路径和文件
# os.listdir(path)
## 获取父路径
# print(os.getcwd())
## 和文件夹相关
# 创建多级路径
# os.makedirs('d1/d2')
# 删除多级路径 有文件的路径不删
# os.removedirs('d1/d2')
# 创建单级目录
# os.mkdir('d3')
# 删除单独路径
# os.rmdir('d3')
# 重命名
# os.rename('d3','d4')
# 删除文件
# os.remove('d4/t.txt')
3 sys 与解释器交互
sys.path() 返回一个列表 模块的搜索路径 可以把要导入的模块路径 加到这个列表中
4 hashlib 加密算法
## 正常加密
import hashlib
md = hashlib.md5() # 实例化对象 这里的md5 可以换别的方法
md.update(bytes) ## 加密
ret = md.hexdigest() ## 十六进制返回值
print(ret)
# 文件可以分批update
# 文件的一致性校验
md = hashlib.md5() ## md5(bytes) 加盐相当于再加密一些
with open(file,mode = 'rb') as f1:
while True:
content = f.read(1024)
if content:
md.update(content)
else:
break