python基础14_文件操作

时间:2023-03-09 16:16:39
python基础14_文件操作

文件操作,通常是打开,读,写,追加等。主要涉及 编码 的问题。

#!/usr/bin/env python
# coding:utf-8 ## open实际上是从OS请求,得到文件句柄
f = open('test', encoding='utf-8') # 打开文件,并且使用指定编码
data = f.read() # 读文件
f.close() # 使用完成要记得释放资源
print(data) f2 = open('t2') # 默认以GBK编码读取,所以需要文件也是以同样的编码保存
print(f2.readable()) # 是否可读
d2 = f2.readline() # 一次读一行,会包括末尾的换行符
print(d2,type(d2))
print(f2.readline())
print(f2.readlines()) #从光标处开始,读取全部至末尾的行,以list的形式
f2.close() ## 文件打开模式: 基本,只读,只写
# 默认是只读模式,
'''
#1. 打开文件的模式有(默认为文本模式):
r ,只读模式【默认模式,文件必须存在,不存在则抛出异常】
w,只写模式【不可读;不存在则创建;存在则清空内容】
a, 之追加写模式【不可读;不存在则创建;存在则只追加内容】 #2. 对于非文本文件,我们只能使用b模式,"b"表示以字节的方式操作(而所有文件也都是以字节的形式存储的,使用这种模式无需考虑文本文件的字符编码、图片文件的jgp格式、视频文件的avi格式)
rb
wb
ab
注:以b方式打开时,读取到的内容是字节类型,写入时也需要提供字节类型,不能指定编码 #3. 了解部分
"+" 表示可以同时读写某个文件
r+, 读写【可读,可写】
w+,写读【可读,可写】
a+, 写读【可读,可写】 x, 只写模式【不可读;不存在则创建,存在则报错】
x+ ,写读【可读,可写】
xb 更多可参考: http://www.cnblogs.com/linhaifeng/articles/5984922.html#_label2
'''
f = open('测试.txt','w',encoding='utf-8')
# f.read() # 只写的文件不可读
print(f.writable()) # 判断是否可写
f.write('1111111111111\n') # 默认会文件内容清空,再写。
f.write('222\n')
f.write('3333333\n') f.writelines(['aaaaaaaa\n','bbbbbb\n']) # 以列表的方式写入,且只能是字符串内容。
f.close() fo = open('测试.txt','a',encoding='utf-8') #
fo.write('kkkkkkkk\nbbbbbb\n大家都来测试吧。')
# print(fo.read()) # 不可读
fo.close()

使用 with 关键字,open的写法不同。

#!/usr/bin/env python
# coding:utf-8 # 使用 with关键字,则打开的文件不用手动关闭,python会自动释放资源 with open('t3','r',encoding='utf-8') as f:
a = f.read()
print(a) # 也可以 with 打开多个文件,换行的话,以 \ 结尾
# 此例自动读取了一个文件,写入到另一个文件。且编码发生改变。
with open('t2','r',encoding='gbk') as f2, \
open('t4','w',encoding='utf-8') as f3:
data = f2.read()
f3.write(data)

一个小练习,模拟了文件修改的过程。

#!/usr/bin/env python
# coding:utf-8 # r+ 模式可读可写,并且容易操作,并且不会清空文件内容。
# fop = open('测试.txt','r+',encoding='utf-8')
# fop.write('9999999999') # 如果 r+ 方式一开始就写,那么会从文件头部开始写。
# c = fop.read()
# print(c)
#
# fop.write('\n\nggggggggggg')
# fop.close() ## 模拟文件的修改过程,即先将文件读入内存,经过程序修改后,再写入硬盘。 srf = open ('t3','r',encoding='utf-8')
da = srf.readlines()
srf.close() print(da)
lis =[]
for i in da:
a = i.replace('','')
lis.append(a) # print(list(lis))
#
dsf = open('t3','w',encoding='utf-8')
dsf.writelines(lis)
dsf.write('88888888888888\n')
dsf.close()

还有那个 seek() 用来操作光标:

#!/usr/bin/env python
# coding:utf-8 f = open('t5','a+',encoding='gbk')
print(f.encoding) # 得到的是打开文件时的编码,跟源文件编码无关
# print(f.read())
f.close() # 如果不关闭,文件则不能删除。 # r+ 模式要注意先读后写 与 先写后读的区别 因为光标所处的位置
fo = open('t6','r+',encoding='utf-8')
fo.write('11111\n')
fo.write('abcde\n')
fo.flush() # 将内存中的操作保存到硬盘
print(fo.name)
print(fo.readlines())
fo.close() fop = open('t6','r',encoding='utf-8',newline='') # newline参数表示不处理OS的特殊字符,原样输出真正的换行符号
print(fop.tell()) # 告诉你光标的位置 断点续传时需要监控光标位置
print(fop.readlines())
print(fop.tell())
fop.close() fope = open('t7','r',encoding='utf-8',newline='') # newline参数表示不处理OS的特殊字符,原样输出真正的换行符号
fope.seek(3) # 光标移动到多少字节,默认从头开始
print(fope.read())
fope.close() fopen = open('t8','r+',encoding='utf-8',newline='') # truncate是截取文件内容,不能以w 或w+ 来打开。
# fopen.seek(5)
fopen.truncate(15) ###### #######
# 文件操作,参考 : http://www.cnblogs.com/linhaifeng/articles/5984922.html#_label13

### seek()控制光标的位置。括号里面是按字节数来控制位置(utf8是3个字节) ### read() 括号里则是按字符数

#!/usr/bin/env python
# coding:utf-8 ### seek()控制光标的位置。括号里面是按字节数来控制位置(utf8是3个字节)
### read() 括号里则是按字符数
## 第二个参数:0 从头开始,1 相对位置开始,2 从末尾倒着来。
## 其中后两种模式只能以 b 方式打开文件
f = open('t8','ab+')
f.seek(0,2) # 直接从文件末尾开始
print(f.read())
f.seek(-2,2) # 从文件末尾往回两个字节
print(f.read())
f.seek(5,2) # 从文件末尾再往后5个字节
f.write('\n8888888'.encode('utf-8')) # 在文件的末尾添加内容 # ## 读取日志文件的最后一行。
with open('log','rb') as fop:
offs = -50
while True:
fop.seek(offs,2)
lis = fop.readlines() # 读取从光标处到末尾
if len(lis) > 1:
print(lis[-1].decode('utf-8'))
break
offs *= 2
#!/usr/bin/env python
# coding:utf-8 import time # b 以二进制字节方式打开文件。 byte
# 好处,是可以跨平台。但是对Linux没什么用,因为Linux本身就是以二进制方式打开文件。
# 可以打开视频 图片 等类型文件。 f = open('t5','rb') # b方式不能指定编码
# f.readable()
a = f.read()
print(a)
print(a.decode('utf-8'))
f.close() # fo = open('t5','wb')
# fo.write(bytes('abcdefg\n大家一起上吧。\n',encoding='utf-8')) # 使用内置bytes函数来转换
# fo.write('今天天气真热\n'.encode('utf-8')) # 直接用字符串的 encode 方法来编码
# fo.close() fo = open('t5','ab')
fo.write(bytes('abcdefg\n大家一起上吧。\n',encoding='utf-8')) # 使用内置bytes函数来转换
fo.write('今天天气真热\n'.encode('utf-8')) # 直接用字符串的 encode 方法来编码
fo.close() ## open 函数如果不传参数,默认以 rt 方式打开