打开文件:
try:f=open("C:/Users/25770/PycharmProjects/PythonProject7/day0108/files/1",'r')print(f.read())finally:iff:f.close()可以简写为:
withopen("C:/Users/25770/PycharmProjects/PythonProject7/day0108/files/1")asf:print(f.read())读取二进制文件:
f=open("C:/Users/25770/PycharmProjects/PythonProject7/day0108/files/1",'rb')写出:
f=open("C:/Users/25770/PycharmProjects/PythonProject7/day0108/files/1",'w')f.write("hello world")追加写出:a:append
f=open("C:/Users/25770/PycharmProjects/PythonProject7/day0108/files/1",'a')f.write("hello world")内存流
- StringIO
StringIO会将字符串读入到内存中
fromioimportStringIO f=StringIO()f.write("hello")f.write("world")print(f.getvalue())f=StringIO("hello ! \n hi \n goodbye")whileTrue:s=f.readline()ifs=="":breakprint(s.strip())- BytesIO
BytesIO实现了在内存中读写bytes ,写入的并不是str,而是经过utf-8编码的bytes
fromioimportBytesIO f=BytesIO()print(f.write("中文".encode("utf-8")))print(f.getvalue())操作文件和目录
操作系统直接操作文件和目录,,用的是os包,,,
os.path.abspath("."):获取当前目录的绝对地址os.path.join(目录1,目录2): 将两个目录连接起来,也可以连接文件os.listdir("."): 获取当前目录下面的所有目录和文件os.path.isdir(): 判断遍历出来的是不是目录
os.path.split(): 将最后一层目录或者文件切割出来 ,返回元组os.path.splitext(): 获取文件的后缀名比如.pyos.rename(原文件名字,新文件名字)os.name: 返回操作系统的名字,,如果是windows返回ntos.environ: 获取环境变量os.environ.get('PATH',default): 获取指定的环境变量os.remove("xxx"): 删除指定文件
遍历文件
print(os.listdir("."))print([xforxinos.listdir(".")ifos.path.isdir(x)])print([xforxinos.listdir(".")ifos.path.isfile(x)andos.path.splitext(x)[1]=='.py'])序列化
序列化: 将内存中的东西,,变成可存储的东西,,这个过程叫做序列化,在python中交pickling…在其他语言中被叫做serilization,marshalling,flattening等
反序列化:重新读取对象到内存中,也就是unpickling
- pickle
python中有一个可以直接序列化为二进制的工具模块pickle:
但是每个解释器都可能不一样,,也就是说,不同的解释器,可能反序列化会失败,,所以只能用pickle保存那些不重要的数据,,不能成功反序列化也没有关系
importpickle d=dict(name="John",age=25)f=open("dump.txt","wb")pickle.dump(d,f)importpickle f=open("dump.txt","rb")print(pickle.load(f))f.close()- json序列化
dumps(): 返回标准的json字符串dump(): 写入到文件loads(): 反序列化
json可以存很多,,但是不能直接存对象,,但是我们大部分都是直接存对象,,
直接存对象就需要先将对象转换成dict然后再存储
importjson d=dict(name="John",age=25)# 返回json字符串json_str=json.dumps(d)# print()j=json.loads(json_str)print(j)defstudent2dict(std):return{'name':std.name,'age':std.age}classStudent():def__init__(self,name,age):self.name=name self.age=age# 将字典还原成对象defdict2student(d):returnStudent(d['name'],d['age'])s=Student("John",25)print(json.dumps(s,default=student2dict))print(s.__dict__)sJson=json.dumps(s,default=lambdao:o.__dict__)print(sJson)s2=json.loads(sJson,object_hook=dict2student)print(s2.name)json.dumps()参数
- default : 默认的转换,,可以自定义函数转换,,也可以使用对象的
__dict__ - ensure_ascii : 默认是true,,,true:表示如果不是在ascii码之内的,就会被转义成
\uxxxx的格式,,如果为false: 保留原始的非ascii字符,,比如直接显示张三
json.loads()参数
- object_hook : 将字典转换成对象的钩子