首页 > 代码库 > python学习 文件操作
python学习 文件操作
一、python打开文件
#=====================python 文件打开方式 open()=====================# open(fileName,type) type="r" 以只读方式打开文件 ,该文件必须存在file_r=open("E:\\python\\hello.txt","r");# open(fileName,type) type="w"#1、以只写方式打开文件 ,该文件如果不存在就创建文件#2、如果该文件存在并且有内容,则会清空内容file_w=open("E:\\python\\hello_w.txt","w");# open(fileName,type) type="a" 以追加的方式打开文件file_a=open("E:\\python\\hello_w.txt","a");# open(fileName,type) type="r+" 或 type="w+" 以读写的方式打开文件file_rr=open("E:\\python\\hello_w.txt","r+");# open(fileName,type) type="a+" 以追加和读写的方式打开文件file_aa=open("E:\\python\\hello_w.txt","a+");
二、python读取文件
#=====================python 文件读取方式 read()=====================# read() 读取全部 read(size) 读取指定数量的字符def readTest(): file_r=open("E:\\python\\hello.txt","r"); str=file_r.read(); print(str); file_r.close();#readline() 读取一行 readline(size) 读取一行中的size个字符(无论size是否大于一行的字符个数,总返回一行中的字符个数)def readLineTest(): file_r=open("E:\\python\\hello.txt","r"); str=file_r.readline(2); print(str); file_r.close();# readLines() 读取全部文件(io.DEFAULT_BUFFER_SIZE),返回每一行所组成的列表(如果文件很大会很占用内存空间)def readLinesTest(): file_r=open("E:\\python\\hello.txt","r"); str=file_r.readlines(18); print(str); file_r.close();#iter: 使用迭代器读取文件def IterTest(): file_r=open("E:\\python\\hello.txt","r"); iter_f=iter(file_r);#将文件转为迭代器, lines=0; for line in iter_f: print(line); lines+=1; print(lines); file_r.close();
三、python写入文件
在介绍文件写入时,先了解一个文件缓存区的概念。
cpu在操作物理内存中的数据(读写)速度是很耗时的,我们的计算机为了提高运行效率,我们的计算机cup内核会对数据参数一个高速缓存区,cup会先操作高速缓存区中的数据,然会在某一时刻将高速缓存区中的数据写入到物理内存中。
所以在文件写入时我们不得不提两个方法 close() 与flush();
#=====================文件关闭 close()====================
# 将缓存数据写入磁盘
# 在linux系统中每个进程打开文件的个数是有限的(如果超过该限度,再打开文件就会失败)所以在每次使用完文件后一定要关闭该文件
#===================== flush()====================
# 将缓存数据写入磁盘
关于cpu缓存代码演示:
创建一个空文件hello.txt
def writerTest(): file=open("E:\\python\\hello.txt","w"); file.write("hello Word");
结果:hello.txt 还是为空
使用:close()会flush()方法
def writerTest(): file=open("E:\\python\\hello.txt","w"); #将数据写入磁盘文件中,但一般我们的cup会有一个文件缓存区,数据一般会先写入cpu的文件缓存区中。 #如果写入字符的数据量大于或等于cpu的文件缓存区大小,那cpu会将该数据自动写入到次磁盘文件中,剩余的字符我们还是需要 #调用flush() 或 close() 方法才能将数据全部写入磁盘文件中。 file.write("hello Word"); #调用flush() 告诉cpu将文件缓存区中的数据写入磁盘文件中,或者直接调用 close()f方法 file.flush(); file.close();
结果:打开hello.txt 内容为 hello Word
writerLines(str):写多行到文件
def writerLinesTest(): file=open("E:\\python\\hello.txt","w"); file.writelines("hello Word"); file.writelines(("hello_1","hello_2","hello_3")); file.writelines(["hello_4","hello_5","hello_6"]); file.close();
四、文件指针
#===================文件指针===================
#文件读写的问题
#写入文件后,必须打开才能读取写入的内容;读取文件后,无法重新再次读取读过的内容
#文件读取原理
#python在进行文件读取过程中,会产生一个文件指针,该指针会记录当前文件被读取的位置。
#如何操作文件指针
#seek(offert,whence):移动文件指针 offset:偏移量可以为负数。whence:偏移相对位置
#os.SEEK_SET:相对文件起始位置
#os.SEEK_CUR:相对文件当前位置
#os.SEEK_END:相对文件结尾位置
#如果文件指针的偏移量大于文件字符个数程序将报错
import os;def seekTest(): file=open("E:\\python\\hello.txt","r+"); str=file.read(3);#读取三个字符 print(str); index=file.tell();#获取当前文件指针的位置 print(index);# 3 #需求:将文件指针移动到起始位置 file.seek(0,os.SEEK_SET); index=file.tell(); print(index);#0 #需求:将文件指针移动到结尾位置 file.seek(0,os.SEEK_END); index=file.tell(); print(index);#9 file.close();
注意:
Python3不允许非二进制打开的文件,相对于文件末尾的定位,这是文档的原文:
In text files (those opened without a b in the mode
string), only seeks relative to the beginning of the file are allowed
(the exception being seeking to the very file end with seek(0, 2)).(https://docs.python.org/3.2/tutorial/inputoutput.html#methods-of-file-objects)
python学习 文件操作
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。