文件
- 长久保存信息的一种数据信息集合
- 常用操作
- 打开关闭(文件一旦打开,需要关闭操作)
- 读写内容
- 查找
open函数
- open函数负责打开文件,带有许多参数
- 第一个参数:必须有,文件的路径和名称
- mode:表明文件用什么方式打开
-
r:以只读方式打开
-
w:写方式打开,会覆盖以前内容
-
x:创建方式打开,如果文件以存在,报错
-
a:append方式,以追加的方式对文件内容进行写入
-
b:binary方式,二进制方式写入
-
t:文本方式打开
-
+:可读写
#打开文件,用写的方式
#r表示后面字符串内容不需要转义
#f称之为文件句柄
f = open(r’test01.txt’,‘w’)
#文件打开后必须关闭
f.close()
#此案例说明,以写方式打开文件,默认是如果没有文件,则创建
-
with语句
-
with语句使用的技术是一种称为上下文管理协议的技术
-
自动判断文件的作用域,自动关闭不再使用的打开的文件句柄
#下面语句块开始对文件f进行操作 #本模块中不需要使用close关闭文件f with open(r'test01.txt','r') as f: strline = f.readline() #次结构保证能够完整读取文件直到结束 while strline: print(strline) strline = f.readline()
-
read是按字符读取文件内容
-
允许输入参数决定读取几个字符,如果没有指定,从当前位置读取到结束
-
否则,从当前位置读取指定个数字符
seek(offset, from)
-
移动文件的读取位置,也叫读取指针
-
from的取值范围:
- 0:从文件开始偏移
- 1:从文件当前位置开始偏移
- 2:从文件末尾开始偏移
-
移动的单位是字节(byte)
-
一个汉字由若干字节构成
-
返回文件只针对当前位置
#打开文件后,从第三个字符开始读取 #打开读写指针在0处,及文件的开头 with open(r'test01.txt','r') as f: #seek移动单位是字节 f.seek(6,0) strChar = f.read() print(strChar)
tell函数
- 用来显示文件读写指针的当前位置
文件写的操作-write
- write(str):把字符串写入文件
- writeline(str):把字符串按行写入文件
- 区别:
-
write函数参数只能是字符串
-
writeline参数只是字符串,也可以字符串序列
#向文件追加一句话
with open(r’test01.txt’, ‘a’) as f:
#注意字符串内含有换行符
f.write("生活不仅是眼前的苟且,\n还有远方的苟且)
-
持久化 - pickle
-
序列化(持久化,落地):把程序的信息保存到磁盘上
-
反序列化:序列号的逆过程
-
pickle:python提供的序列化模块
-
pickle.dump:序列化
-
pickle.load:反序列化,从磁盘中读出
#序列化实例 import pickle age = 19 with open(r'test01.txt','wb') as f: age = pickle.dump(age,f) #反序列化实例 import pickle with open(r'test01.txt','rb') as f: age = pickle.load(f) print(age)
持久化-shelve
-
持久化工具
-
类似字典,用kv对保存数据,存取方式根字典也类似
-
open,close,必需成对出现
#使用shelve创建文件并使用 import shelve #打开文件,shv相当于一个字典 shv = shelve.open(r'shv.db') shv['one'] = 1 shv['two']= 2 shv['three'] = 3 shv.close() #以上案例发现,shelve自动创建的不仅仅是一个shv.db文件,还包括其他格式文件 #shelve读取案例 shv = shelve.open(r'shv'.db) try: print(shv['one']) print(shv['three']) except Exception as e: print("我喜欢明月") finally: shv.close()
shelve特性
- 不支持多个应用并行写入
- 为了解决这个问题,open的时候可以使用flag=r
- 写回问题
-
shelve一般情况下不会等待持久化对象进行任何修改
-
解决方案:强制写回:writeback=True
#shelve 使用with管理上下文环境
with shelve.open(r’shv.db’, writeback = True) as ahv:
k1 = shv[‘one’]
print(k1)
k1 [“eins”] = 1000
with shelve.open(r’shv.db’) as shv:
print(shv[‘one’])
-