文件操作
文件的打开模式
1、 r:只读(默认的)
在文件不存在时则报错,文件存在时文件指针跳到文件开头
f=open('xxx.txt',mode='rt',encoding='utf-8')
res=f.read()
print(f.readable()) #判读当前打开文件的模式
print(f.writable())
f.close()
2、 w: 只写
在文件不存在则创建空文件,文件存在时则清空,文件指针跳到文件开头
f=open('xxx.txt',mode='wt',encoding='utf-8')
f.write('hello\n')
f.write('你好啊')
f.close()
程序关闭前在w的模式下可以写多个write且不会覆盖内容,但当这个模式开始时,原本写入文件内容已经清空
3、 a:只追加写
在文件不存在时则创建空文件,文件存在时也不会清空,文件指针跳到文件末尾
f=open('xxx.txt',mode='at',encoding='utf-8')
f.write('jason:777\n')
f.write('arther:888\n')
f.close()
总结:w和a的异同
相同点:在打开了文件不关闭的情况下,连续地写入,新的内容永远跟在老内容之后
不同点:重新打开了文件,w会清空老的内容,而a模式会保留老的内容并且指针跳到文件末尾
文件操作的其他方式
读相关方法:
with open('login.txt',mode='rt',encoding='utf-8')as f:
# line1=f.readline()
# line2=f.readline()
# line3=f.readline()
# print(line1)
# print(line2)
# print(line3)
lines=[]
for line in f:
lines.append(line)
print(lines)
lines=f.readlines()#相同循环取值
print(lines)
['arther:123\n', 'egon:456\n', 'tank:789\n']
with open('lock.txt',mode='rt',encoding='utf-8') as f:
a=f.read()
with open('xxx.txt',mode='wt',encoding='utf-8')as f:
lis=['111\n','222\n','333\n']
# f.write(lis) #list写不进去
for i in lis:
f.write(i) #相同
f.writelines(lis) #循环写入lis内的字符串内容
f.writelines('hello')
f.write('hello')
结果看似相同,前者是循环写入字符串内的每一个字符,后者直接写入
with open('xxx.txt', mode='wt', encoding='utf-8')as f:
print(f.name)
print(f.closed)
for i in range(100):
f.write('%s\n' % i)
f.flush()
每一次循环刷新一次,将本次循环的内容写入文件
不然按照默认是在不影响内存的情况下攒一波存入进去
好处是能够准确无误的将每一次内容准时写入文件中
坏处是过度的使用了操作系统,会影响到操作系统的性能
控制文件指针的移动
控制文件内指针的移动都是以字节为单位
只有一种特殊情况,t模式下的read(n),代表是n个字符,此外代表的全是字节
with open('xxx.txt',mode='rt',encoding='utf-8')as f:
data=f.read(5)
print(data) #读出了中午字符你
with open('xxx.txt',mode='rb')as f:
data=f.read() #此时是字6个字节,中文符号是3个字节
print(data)
print(data.decode('utf-8')) #不能编译,因为么有完整的三个中文字节
f.seek(n,模式) #n代表移动的字节个数
0模式
参照文件的开头开始移动(只有0模式下可以在t下使用,1和2模式只能在b下使用)
with open('xxx.txt',mode='rt',encoding='utf-8')as f:
f.seek(5,0)
print(f.tell())
print(f.read())
print(f.tell()) #此时读完后指针在最后
f.seek(0,0)
print(f.read())
f.seek(6,0)
print(f.read()) #报错 因为在中文的第一字节开始,无法读出完整中文符号
1模式
参照指针当前所在的位置
with open('xxx.txt',mode='rb') as f:
f.seek(3,1)
f.seek(3,1)
print(f.tell()) #6个字节
f.seek(3,0)
f.seek(2,1)
print(f.read().decode('utf-8')) #你好
2模式
参照文件末尾的位置
with open('xxx.txt',mode='rb')as f:
f.seek(-3,2)
print(f.tell()) #从文件头开始数
print(f.read().decode('utf-8'))
#f.truncate(n)从文件开头往后数n个字节保留下来,其余的全部删除
#f.truncate从文件开头往后数指针当前所在的位置,其余全部删除