文件操作
fp = open(“文件名”,mode=“模式”,encoding=“utf-8”)
fp -> 文件的io对象 (文件句柄)
i => input 输入
o => output 输出
一.文件的写入
# 1.打开文件
fp = open("ceshi1.txt",mode="w",encoding="utf-8")
# 2.写入内容
fp.write("把内容写进去")
# 3.关闭文件
fp.close()
** 二.文件的读取**
# 1.打开文件
fp = open("ceshi1.txt",mode="r",encoding="utf-8")
# 2.读取内容
res = fp.read() # 把大象拿出来
print(res)
# 3.关闭文件
fp.close()
** 三.字节流的转换**
bytes : 是用来传输或者存储的数据格式
b’1234’ b"abcd" b"我爱你" -> b开头的字节流,范围只能是ascii编码
如果是中文使用encode 和 decode 来进行转换;
将字符串和字节流(Bytes流)类型进行转换 (参数写成转化的字符编码格式)
#encode() 编码 将字符串转化为字节流(Bytes流)
#decode() 解码 将Bytes流转化为字符串
encode 编码 => 变成二进制字节流
res = strvar.encode(“utf-8”)
print(res , type(res))
<========>
decode 解码 =>二进制字节流恢复成原来的字符串
res2 = res.decode(“utf-8”)
print(res2 , type(res2))
len可以计算字节个数
num = len(res)
print(num) # 9
四.存储二进制字节流
不需要指定encoding编码集,否则报错
五.读取二进制字节流
res = fp.read()
六.复制图片(图片,音频,视频)
1. 读取原图片所有的内容
fp = open("集合.png",mode="rb")
res = fp.read()
fp.close()
2. 把读取的内容存储到另外一个文件
fp = open("集合2.png",mode="wb")
指定绝对路径(完整路径)
fp = open(r"E:\python31\day8\集合3.png",mode="wb")
fp.write(res)
fp.close()
文件的扩展模式
(utf-8编码格式下 默认一个中文三个字节 一个英文或符号 占用一个字节)
(1)r+ 可读可写
fp = open("test1.txt",mode="r+",encoding="utf-8")
res = fp.read()
fp.write("789")
fp.close()
print(res)
注意点:r,r+ 模式下,
1、文件必须存在才能创建文件IO对象(fp)
2、光标会停止在读写终止的位置
(2)w+ 可读可写
fp = open("test2.txt",mode="w+",encoding="utf-8")
fp.write("梦想起航")
fp.seek(0)
res = fp.read()
fp.close()
print(res)
注意点:w,w+ 模式下,
1、文件不存在时可自动创建
2、光标会停止在读写终止的位置(同r,r+)
3、该模式下,生成文件IO对象(fp)时已默认清空文件内容(慎用)
(3)a+ (可读可写)(写入内容时强制把光标移动到最后)
fp = open("test3.txt",mode="a+",encoding="utf-8")
fp.seek(0)
fp.write("789")
fp.seek(0)
res = fp.read()
fp.close()
print(res)
注意点:a,a+ 模式下,
1、文件不存在时可自动创建
2、写入时光标会被强制放到文件内容末尾(区别于r,w)(即使使用seek移动时也不行)
3、该模式下,生成文件IO对象(fp)时已默认清空文件内容(慎用)
read seek tell 三个函数
#read() 功能: 读取字符的个数(里面的参数代表字符个数)
#seek() 功能: 调整指针的位置(里面的参数代表字节个数)
#tell() 功能: 当前光标左侧所有的字节数(返回字节数)
seek(0) 直接把光标移动到文件开头
seek(0,2) 直接把光标移动到文件末尾
tell() 计算文件指针左侧所有的字节数
***注意点,seek移动中文字节的时候,有可能报错
三.with语法的使用 (close操作with语法可以自动实现
with open("集合.png",mode="rb") as fp:
res = fp.read()
with open(r"E:\python31\day8\集合4.png",mode="wb") as fp:
fp.write(res)
优化合并如下:
with open("集合.png",mode="rb") as fp1 , open(r"E:\python31\day8\集合5.png",mode="wb") as fp2:
res = fp1.read()
fp2.write(res)
close 文件关闭的意义
刷新缓冲区 flush
# 当文件关闭的时候自动刷新缓冲区
# 当整个程序运行结束的时候自动刷新缓冲区
# 当缓冲区写满了 会自动刷新缓冲区
# 手动刷新缓冲区
fp.flush() 手动把缓冲区里面的内容写入文件当中
文件的相关函数
readable() 判断文件对象是否可读
writable() 判断文件对象是否可写
readline() 读取一行
‘’’‘参数 > 当前行字符总个数 => 以当前行读取
参数 < 当前行字符总个数 => 以参数的大小来读取字符的个数
默认readline 读取一行’’’
readlines() 将文件中的内容按照换行读取到列表当中
lst_new = []
with open("ceshi7.txt",mode="r+",encoding="utf-8") as fp:
lst = fp.readlines()
# print(lst) # ['\t窗前明月光\n', '疑是地上霜\t\t\n', '\t\t举头王明月\n', '\t低头思故乡']
for i in lst:
lst_new.append(i.strip())
print(lst_new) # ['窗前明月光', '疑是地上霜', '举头王明月', '低头思故乡']
writelines() 功能:将内容是字符串的可迭代性数据写入文件中 参数:内容为字符串类型的可迭代数据
lst = ["春眠不觉晓\n","处处蚊子咬\n","夜来大狗熊\n","一个也跑不了\n"]
# lst = [1,2,3,4] error
with open("ceshi8.txt",mode="w",encoding="utf-8") as fp:
fp.writelines(lst)
truncate() 功能: 把要截取的字符串提取出来,然后清空内容将提取的字符串重新写入文件中 (字节)
with open("ceshi8.txt",mode="r+",encoding="utf-8") as fp:
fp.truncate(3)