python文件处理

1.文件介绍
python操作文件

1.python文件的基本操作 打开文件关键字open 语法格式:open('文件路径','读写模式','字符编码') f = open('a.txt','r',encoding='utf-8')#打开文件 print(f.read())#操作文件 f.close()#关闭文件 2.with上下文管理器(with打开文件之后会自动关闭) 语法格式:with open(r'a.txt','r',encoding='utf-8') as f: as f:就相当于你写了一个f = open,只不过这个as替换了等于号,这个f(句柄)就相当于一个变量名可以随意更改 r 的作用:有时有你在填写路径的时候遇到反斜杠可能会发生转义,这个时候字符串最前面加上 r 来解决转义的问题, 

2.文件的读写模式

1. r  == read: 只读,不能写 with open(r'a.txt','r',encoding='utf-8') as f: f.read() #read()是有缺陷的,如果打开文件特别大的时候就会打不开,会很慢。会导致内存溢出,因为他打开不会存在磁盘中,会先存在内存中   2. w ==write:只能写,不能读 with open(r'a.txt','w',encoding='utf-8') as f: f.write('内容') #如果路径不存在,会新建一个文件 #如果文件存在,会先清空文件中的内容,在进行写内容,就算不写东西用pass,也会清空,w模式就会直接清空 # w 模式只能写string类型  3. a == apppen : 追加 with open(r'a.txt','a',encoding='utf-8') as f: f.write('内容n') #如果路径不存在,会新建一个文件 #不会清空文件内容,但是不会换行,需要自己在内容后面加n 多行数据:括号里不可能写多行数据,需要多个write如下: f.write('内容n') f.write('内容n') f.write('内容n') f.write('内容n') ########r,w, a:只能读写文档,不能读写视频音频  

3.文件的操作方法

读模式 with open(r'a.txt','a',encoding='utf-8') as f: print(f.readline())#一次读取一行,会自动换行 print(f.readlines())#把文件内的数据按照每一行组装成列表的模式 print(f.readable())#判断是否可具备读的条件,就是看这个文件是否可读,返回bool值  写模式 with open(r'a.txt','a',encoding='utf-8') as f: print  (f.write())#直接清空数据,然后根据口号中的内容写数据 print(f.writeable())#判断是否具备写的条件,返回bool值 print(f.writelines(['献运好帅n','献运好帅n','献运好帅n',]))#就是吧数据一行一行的给你去写  文件的操作优化 print(f.flush())#把内存中的数据立刻刷到硬盘中,因为你一开始写的数据会存储在内存中如果发生断电数据会消失 """文件句柄 f 支持for循环""" with open(r'a.txt','a',encoding='utf-8') as f:   for line in f : print(line)#把文件里面的数据一行一行打印,以后读取文件的时候都要用for循环一行一行的去读取 

4.文件的操作模式

r. w. a. 模式 1. 只能操作文本 2. 都是以字符串为单位 3. r,w,a,原先的写法是rt,wt,at,如果是只操作文本这个t可以省略  b模式:二进制 1.能操作任何的数据类型,eg:文本,音频,视屏 2.写法:rb ab wb  :此时的b不能省略 3.b模式的情况下encoding参数不能写,因为他都是字符编码的模式了encoding就没用了  rb: with open(r'a.jpeg','rb') as f:#b模式的话字符编码就不要了 print(f.read())#打印出一推二进制数 wb: with open(r'a.jpeg','rb',encoding='utf-8') as f: f.write(b'你好')#你好前面必须加上b才可以打印出,不然出来的是乱码注释第一种编码方式 s.'你好' f.write(s.encode(utf8))#这是第二种编码方式 """wb写进去了也必须rb来读,然后后面还需要跟上decode去解码 print(f.read().decode('utf8')) """ 按照字符或字节读取:要注意他读取的数据大小 with open(r'a.txt','a',encoding='utf-8') as f: print(f.read(1))#当 r 模式下,read括号里面的数字代表的是字符,但是在 b 模式下read后面括号里面的代表的是字节 

发表评论

相关文章