python中文件的相关操作和函数

文件操作

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)

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值