Python编程之文件操作

文件操作流程

打开文件,得到文件句柄并赋值给一个变量

通过句柄对文件进行操作

关闭文件

每次文件打开、读取信息时,Python自动记录所达到的位置,好比一个书签,之后每一次读取都会从上次结束的地方开始,如果要从开始的位置读取,可以将其关闭后打开。

文件操作模式

r :只读模式 (默认)

w :只写模式 (不可读;如果文件不存在,则创建新文件;如果文件存在,则删除原内容

a :追加模式 (不可读;如果文件不存在,则创建新文件;如果文件存在,则在文件末追加内容)

r+ :可读可写,追加形式写入,读取行位置不变

w+ :写读,覆盖形式写入,此时在文件最后,如果需要读取文件,则需要使用seek

a+ :可读可写,追加形式写入,以这个模式打开文件,默认在文件末尾,如果需要读取文件,则需要使用seek

b : 处理二进制文件(FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注),在socket编程中,python3.x以二进制传输,需要encode,python2.x可以通过字符串传输

rb: 二进制形式读取文件,注意此时不能有encoding = "utf-8",会报错ValueError。

wb:

ab:

U:表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用,例如:rU 或 r+U)

文件缓存:写入文件时,可能写入内容还在缓存中,并没有写进硬盘,可以通过flush方法冲刷缓存,写进硬盘中。

with语句:当with代码块执行完毕时,内部会自动关闭并释放文件资源。

python2.7之后,with支持同时对多个文件的上下文管理。

文件读写操作

#*************************读************************
#默认读取,则整个文件以字符串形式返回
f = open("file","r",encoding="utf-8") #文件句柄,输出中文时注意文件编码
data = f.read() #读取剩下的所有内容,文件大时不建议使用
data2 = f.read() #此时文件已经读取完,书签在文件末,data2中为空
print(data)
print("---------------")
print(data2)
f.close() #按指定字符数
f = open("file","r",encoding="utf-8")
print(f.read(1))
print(f.read(4))
f.close()

当作人杰 #按行读取
f = open("file","r",encoding="utf-8")
print(f.readline())
print(f.readline())
f.close() #原文档有回车,所以有一个空行 f = open("file","r",encoding="utf-8")
lines = f.readlines()
print(lines,len(lines))
f.close()
['生当作人杰\n', '死亦为鬼雄\n', '至今思项羽\n', '不肯过江东'] 4 #for循环迭代
f = open("file","r",encoding="utf-8")
for line in f: #一行一行的读,效率比较高
print(line)
f.close() #模块自动关闭文件
with open('file','r',encoding="utf-8") as f:
print(f.read()) #*****************写*******************
text_file = open("write_it.txt","w") #会自动创建一个新文件,原来如果有个这个文件,则会覆盖,慎用
text_file.write("Line 1\n")
text_file.write("This is line 2\n")
text_file.write("That makes this line 3\n") #将字符串列表写入到文件
text_file = open("write_it.txt","w")
lines = ["Line \n",
"This is line 2\n",
"That makes this line 3\n"]
text_file.writelines(lines)
text_file.close()

文件追加与修改操作

#*****************追加*******************
f = open("file","a",encoding="utf-8") #在文件后追加信息,注意使用“\n”
f.write("\n李清照")
f.close() #**********************可读可写模式******************
f = open("file","r+",encoding="utf-8") #文件句柄,输出中文时注意文件编码
data = f.read() #读取剩下的所有内容,文件大时不建议使用
f.write("\n南宋")
f.close() #**********************修改文件******************
f = open("file","r",encoding="utf-8") #文件句柄,输出中文时注意文件编码
f_new = open("file.bak","w",encoding="utf-8")
for line in f:
if "西天的云彩" in line:
line = line.replace("西天的云彩","今天的离别")
f_new.write(line)
f.close()
f_new.close()
#结论:通过匹配要修改的内容修改,保存在另外一个新建文件中。

二进制文件操作

f = open("file","rb")    #文件句柄,输出中文时注意文件编码
print(f.read())
f.close()
#b'hello world' f = open("file","wb") #文件句柄,输出中文时注意文件编码
f.write("Hello world\n".encode())
f.close()

with语句操作

with open("loginlog.txt","r") as f:
for line in f:
print(line) #代码块执行完毕后会自动关闭文件 #with打开多个文件
with open("loginlog.txt","r") as f,\ #python代码规范,一行尽量不要超过80个字符,建议用\换行
open("","r") as f2:
for line in f:
print(line)

文件其他操作

#**********文件的其他用法********************
f = open("file","r",encoding="utf-8")
print(f.tell()) #tell 返回文件当前位置,按字节计算
date = f.readline()
date = f.readline()
print(f.tell())
f.seek(15) #seek 移动到文件某个字符位置,一个汉字为3个字节
#seekable 是否可以移动,tty文件不可以
print(f.readline())
print(f.encoding) #encoding 返回文件编码
print(f.fileno()) #fileno 调用操作系统哪个接口
print(f.flush()) #flush 冲刷文件的内部缓存
f.truncate(10) #从头开始截断,原文件只剩下10个字符,不指定参数会清空原文件,
f.close()

文件操作问题

#***********************文件操作问题******************
#文件内容: abcdefghijklmno
#**************模式:r+************************
f = open("file","r+",encoding="utf-8")
print("初始位置:", f.tell())
data2 = f.read(5)
print("-------%s-------" % (data2) )
print("读取五个字母之后的位置:", f.tell())
f.write("a")
print("写入一个字母之后的位置:", f.tell())
data = f.read(5)
print("-------%s-------" % (data) )
print("再次读入五个字母之后的位置:", f.tell())
f.close()
初始位置: 0
-------abcde-------
读取五个字母之后的位置: 5
写入一个字母之后的位置: 19 #追加
-------fghij------- #从第6个位置开始读
再次读入五个字母之后的位置: 19
#结论:读取正常,在文件末尾添加,但是继续读取和tell()返回的值不一致
#问题:如果先写再读,则不是追加,会从文件开始覆盖增加
f = open("file","r+",encoding="utf-8") #文件句柄,输出中文时注意文件编码
f.write("yyy")
print("写入字母之后的位置:", f.tell())
data2 = f.read(5)
print("-------%s-------" % (data2) )
print("读取字母之后的位置:", f.tell())
f.write("zzz")
print("写入字母之后的位置:", f.tell())
data = f.read(5)
print("-------%s-------" % (data) )
print("再次读入五个字母之后的位置:", f.tell())
f.close()
写入字母之后的位置: 3
-------defgh-------
读取字母之后的位置: 8
写入字母之后的位置: 17
-------ijkzz-------
再次读入五个字母之后的位置: 17
#修改:加入seek(0,2),
f = open("file","r+",encoding="utf-8") #文件句柄,输出中文时注意文件编码
f.seek(0,2)
f.write("yyy")
print("写入字母之后的位置:", f.tell())
data2 = f.read(5)
print("-------%s-------" % (data2) )
print("读取字母之后的位置:", f.tell())
f.write("zzz")
print("写入字母之后的位置:", f.tell())
data = f.read(5)
print("-------%s-------" % (data) )
print("再次读入五个字母之后的位置:", f.tell())
f.close()
#结论:在文件末添加,但是读取会出现异常,需要添加seek(0) #******************模式:w+*********************
f = open("file","w+",encoding="utf-8") #文件句柄,输出中文时注意文件编码
print("初始位置:", f.tell())
f.write("abcdefghijk")
print("写入字母之后的位置:", f.tell())
data2 = f.read(5)
print("-------%s-------" % (data2) )
print("读取字母之后的位置:", f.tell())
f.write("zzz")
print("写入一个字母之后的位置:", f.tell())
data = f.read(5)
print("-------%s-------" % (data) )
print("再次读入五个字母之后的位置:", f.tell())
f.close()
初始位置: 0
写入字母之后的位置: 11
--------------
读取字母之后的位置: 11
写入一个字母之后的位置: 14
--------------
再次读入五个字母之后的位置: 14
#修正:在第一次写入后,加seek(0)情况
初始位置: 0
写入字母之后的位置: 11
当前位置: 0
-------abcde-------
读取字母之后的位置: 5
写入字母之后的位置: 14
-------fghij-------
再次读入五个字母之后的位置: 14
#******************模式:a+****************
f = open("file","a+",encoding="utf-8")
print("初始位置:", f.tell())
data2 = f.read(5)
print("-------%s-------" % (data2) )
print("读取字母之后的位置:", f.tell())
f.write("zzz")
print("写入字母之后的位置:", f.tell())
data = f.read(5)
print("-------%s-------" % (data) )
print("再次读入五个字母之后的位置:", f.tell())
f.close()
--------------
读取字母之后的位置: 11
写入字母之后的位置: 14
--------------
再次读入五个字母之后的位置: 14
#结论:在文件后追加,读取文件有问题,没有输出
#修改:在第一次读取前添加seek(0)
-------abcde-------
读取字母之后的位置: 5
写入字母之后的位置: 17 #追加
-------fghij------- #从第6个位置开始读
再次读入五个字母之后的位置: 17
#结论: 添加seek(0)可以解决读取的问题,但是tell()返回位置和继续读取位置不一样

Python修炼之路-文件操作的更多相关文章

  1. Python学习之路——文件操作

    文件操作分三步:打开文件,读写文件,关闭文件.读取操作时没有给read函数加括号,会出现下面这样的车祸 >>> data = open('/home/supersun/Documen ...

  2. 十四、python沉淀之路--文件操作

    一.文件操作b模式 1. # f = open('test11.py','rb',encoding='utf-8') # 这种情况会报错 f = open('test11.py','rb') # b ...

  3. 十三、python沉淀之路--文件操作

    一.文件的读操作 例1 f = open('学习',encoding='utf-8') #首先要打开文件,不然直接读,是读不出来的 data = f.read() #read后的括号里不添加任何东西 ...

  4. Python之路----文件操作

    文件操作 1.能调用方法的一定是对象,比如数值.字符串.列表.元组.字典,甚至文件也是对象,Python中一切皆为对象. str1 = 'hello' str2 = 'world' str3 = ' ...

  5. Python之路-文件操作(py3)

    文件操作的基本步骤: 1.打开文件:f=open('filename'),with open('filename') as f 2.操作文件:增,删,改,查 3.关闭文件:f.close 打开文件 p ...

  6. python之路——文件操作

    阅读目录 初窥文件操作基本流程 文件编码 文件的打开模式 文件内的光标移动 with上下文管理 文件的修改 练习 回到顶部 初窥文件操作基本流程 计算机系统分为:计算机硬件,操作系统,应用程序三部分. ...

  7. 百万年薪python之路 -- 文件操作

    1.文件操作: f = open("zcy.txt" , mode="r" , encoding="UTF-8") open() 打开 第一 ...

  8. 第三章:Python基础の函数和文件操作实战

    本課主題 Set 集合和操作实战 函数介紹和操作实战 参数的深入介绍和操作实战 format 函数操作实战 lambda 表达式介绍 文件操作函数介紹和操作实战 本周作业 Set 集合和操作实战 Se ...

  9. Python基础知识(八)----文件操作

    文件操作 一丶文件操作初识 ###f=open('文件名','模式',编码): #open() # 调用操作系统打开文件 #mode #对文件的操作方式 #encoding # 文件的编码格式 存储编 ...

随机推荐

  1. Go语言基本类型

    1.Go语言fmt包详解 fmt.Println() ###常用打印 fmt.Print() fmt.Printf() ###格式化 fmt.Sprintf() ###字符串拼接 a)普通占位符 占位 ...

  2. LVS 四层 TCP/UDP 负载均衡器

    目录 文章目录 目录 LVS LVS 应用结构 LVS 提供的三种模式 LVS-NAT LVS-TUN LVS_DR LVS 负载均衡算法 静态负载均衡 动态负载均衡 LVS-ipvsadm 指令集 ...

  3. Java编写时钟 Applet 程序

    简单分析: package clockApplet; import java.applet.Applet; import java.awt.Color; import java.awt.Graphic ...

  4. 阶段3 2.Spring_10.Spring中事务控制_6 spring基于XML的声明式事务控制-配置步骤

    环境搭建 新建工程 把对应的依赖复制过来 src下内容复制 配置spring中的声明事物 找到bean.xml开始配置 配置事物管理器 里面需要注入DataSource 2-配置事物通知 需要先导入事 ...

  5. sudo apt -y upgrade

    sudo apt -y upgrade     直接upgrade,不再询问y/n 但是如果是sudo apt-get install scilab -y 那么,就不再显示上图中的信息,即当安装包的时 ...

  6. 【HANA系列】【第八篇】SAP HANA XS使用Data Services查询CDS实体【二】

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列][第八篇]SAP HANA XS ...

  7. MySQL:添加用户、删除用户、授权、远程访问、修改密码

    1.创建用户 #test表示你要建立的用户名,后面的123456表示密码, #localhost限制在固定地址localhost登陆 CREATE USER test@localhost IDENTI ...

  8. 【PyTorch】PyTorch中的梯度累加

    PyTorch中的梯度累加 使用PyTorch实现梯度累加变相扩大batch PyTorch中在反向传播前为什么要手动将梯度清零? - Pascal的回答 - 知乎 https://www.zhihu ...

  9. 【VS开发】【图像处理】RGB Bayer Color分析

    RGB Bayer Color分析 Bayer色彩滤波阵列 拜耳色彩滤波阵列(Bayer Color Filter Array,CFA)是非常有名的彩色图片的数字采集格式.色彩滤波器的模式如上图所示, ...

  10. [转帖]Ubuntu 18.04 server安装图形界面及realvnc远程桌面连接

    Ubuntu 18.04 server安装图形界面及realvnc远程桌面连接 https://blog.csdn.net/networken/article/details/88938304 转帖 ...