Python3.5文件读与写操作经典实例详解

 更新时间:2019年05月01日 09:42:05   作者:loveliuzz  
这篇文章主要介绍了Python3.5文件读与写操作,结合实例形式详细分析了Python针对文件的读写操作常用技巧与相关操作注意事项,需要的朋友可以参考下

本文实例讲述了Python3.5文件读与写操作。分享给大家供大家参考,具体如下:

1、文件操作的基本流程:

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

(2)通过句柄对文件进行操作

(3)关闭文件

2、基本操作举例:

现有一个命名为song.txt的文件,里面存放最喜爱的英文歌,内容如下:

take me to your heart
hiding from the rain and snow
藏身于雨雪之中
trying to forget but i won't let go
努力忘记,但我怎能就这样离去
looking at a crowded street
看着熙熙攘攘的街道
listening to my own heart beat
却只能听见自己的心跳
so many people all around the world
这么多的人在世界上
tell me where do i find someone like you girl
请告诉我在哪里可以找到像你一样的女孩
take me to your heart take me to your soul
将我留存心间与你的灵魂相伴
give me your hand before i'm old
给我你的手,在我老去之前
show me what love is haven't got a clue
问情为何物在我们彼此离开前
show me that wonders can be true
问奇迹上演
they say nothing lasts forever
他们说没有什么可以天长地久
we're only here today
我们也能此时相守
love is now or never
现在或者永不回头
bring me far away
请带我一起远走
take me to your heart take me to your soul
让我靠近你的心与你的灵魂相伴
give me your hand and hold me
给我你的手拥我入怀
show me what love is be my guiding star
问情为何物让星辰照亮我路
it's easy take me to your heart
其实爱我真的很简单以

在另一个命名为file_operation.py的文件中编写代码,使得以“utf-8”的编码格式将文件song.txt打开,并且读取该文件,将读取的内容返回到一个变量lyric中并打印出来。
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# Author:ZhengzhengLiu

lyric = open("song",encoding="utf-8").read()
print(lyric)

运行结果将song.txt文件的内容打印出来:截图部分如下

3、文件基本操作

文件句柄:打开文件的返回值为文件句柄(文件的内存对象),对文件进行操作的是操作文件句柄。

(1)读文件内容

f = open("song",encoding="utf-8") #打开文件的返回值为文件句柄(文件的内存对象)
lyric = f.read() #读文件
print(lyric)  #打印读取内容

(2)写文件内容

f = open("song2",'w',encoding="utf-8") #w:只写模式。不存在的文件则创建;存在则覆盖原来文件的内容
f.write("Take me to your heart\n")
f.write("带我走进你的心")
f.close()

运行结果:

(3)在文件后边追加内容

f = open("song2",'a',encoding="utf-8") #a:追加模式。不存在的文件则创建;存在只追加内容
f.write("\nTake me to your soul\n")
f.write("带我走进你的心灵")
f.close()

运行结果:

(4)文件打开模式总结

.r,只读模式(默认)。
.w,只写模式。【不可读;不存在的文件则创建;存在则覆盖原来文件的内容】
.a,追加模式。【不可读;   不存在则创建;存在则只追加内容】

4、文件读操作

(1)文件读操作——读文件的第一行——调用:句柄.readline()

f = open("song",'r',encoding="utf-8")
first_line = f.readline() #读取第一行
print(first_line)

运行结果:

take me to your heart

(2)文件读操作——利用循环读取文件的前5行:

f = open("song",'r',encoding="utf-8")
for i in range(5):
 print(f.readline().strip())

运行结果:

take me to your heart
hiding from the rain and snow
藏身于雨雪之中
trying to forget but i won't let go
努力忘记,但我怎能就这样离去

句柄.readlines()将文件的内容以每行作为一个元素转换成一个列表

f = open("song",'r',encoding="utf-8")
print(f.readlines())

运行结果:


(3)文件读操作——利用句柄.readlines()循环读取文件的内容:

f = open("song",'r',encoding="utf-8")
for line in f.readlines():
 print(line.strip())

运行结果:

(4)文件读操作——利用句柄.readlines()循环读取文件的内容并处理特殊的行:

f = open("song",'r',encoding="utf-8")
for index,line in enumerate(f.readlines()):
 if index == 5:
  print("------------")
  continue
 print(line.strip())

运行结果:

(5)高效读取文件:当文件的内容很大时,采用readlines的方式需要先把文件转换成列表,耗费时间太长,内存里装不下太大的文件。
采用遍历并打印句柄的方式可以高效的实现文件的读取,这种方式采用一行行读取文件方式,内存里面每次只保存一行

f = open("song",'r',encoding="utf-8")
for line in f:
 print(line.strip())

运行结果:

(6)高效读取文件——处理特殊行

count = 0
f = open("song",'r',encoding="utf-8")
for line in f:
 if count == 3:
  print("-------------")
  count+=1
  continue
 print(line.strip())
 count += 1

5、文件读完之后,文件句柄的指针移动到文件的末尾,想从头再读一遍,需要将指针移回到开始位置。

(1)查看文件句柄的指针指向的位置,调用.tell(),已读取的字符的个数即为计数的值(也是文件句柄指针指向的位置)

f = open("song",'r',encoding="utf-8")
print(f.tell())
print(f.readline().strip()) #读取第一行
print(f.tell())

运行结果:

 0
take me to your heart
23

f = open("song",'r',encoding="utf-8")
print(f.tell())
print(f.read(6)) #读取字符的个数
print(f.tell())

运行结果:

0
take m
6

(2)移动文件句柄指针,使其回到某个位置,调用.seek(指针的位置)

f = open("song",'r',encoding="utf-8")
print(f.tell())
print(f.readline().strip()) #读取第一行内容
print(f.tell())    #打印文件句柄指针的位置
f.seek(0)      #文件句柄指针回到起始位置
print(f.tell())
f.seek(30)     #文件句柄指针回到第30个字符的位置
print(f.readline().strip()) #从第30个字符开始读一行内容
print(f.tell())    #打印读取之后指针的位置

运行结果:

0
take me to your heart
23
0
from the rain and snow
54

6、打印文件的编码类型——调用:句柄.encoding()

f = open("song",'r',encoding="utf-8")
print(f.encoding)    #打印文件的编码类型

运行结果:

utf-8

7、打印文件的名字——调用:句柄.name

f = open("song",'r',encoding="utf-8")
print(f.name)    #打印文件名字

运行结果:

song

8、判断文件是否可读——调用:句柄.readable()

    判断文件是否可写——调用:句柄.writable()

   判断文件是否已经关闭——调用:句柄.closed()

    判断文件句柄指针是否可移动——调用:句柄.seekable(),tty文件和终端设备文件的句柄指针不能移动

f = open("song",'r',encoding="utf-8")
print(f.readable()) #判断文件是否可读
print(f.seekable()) #判断文件句柄指针是否可移动
print(f.writable()) #判断文件是否可写

运行结果:

True
True
False

9、以写的模式打开一个文件,刚写完一行,突然断电,写的内容就没有写入硬盘当中,而是在内存的缓存中(硬盘的速度比内存慢)。
原本等到写入的内容在内存的缓存中满了,再一起写入硬盘中,调用句柄.flush()表示强制刷新到硬盘里面

举例:动态打印字符:每隔0.1秒在屏幕输出打印一个#,一个打印20个

import sys,time

for i in range(20):
 sys.stdout.write("#") #向屏幕标准输出写入的字符
 sys.stdout.flush()  #强制刷新
 time.sleep(0.1)   #休眠时间

运行结果

####################

10、截断文件里面的内容——调用:句柄.truncate()   没有写参数,不做任何操作

调用:句柄.truncate(10)    参数10,代表从文件开头,截断10个字符

f = open("song",'a',encoding="utf-8")
f.truncate(20)    #从起始位置截断20个字符

11、"+" 表示可以同时读写某个文件

(1)r+   读写模式,注:写的内容从文件的最后面开始写入(写等同于追加),即:【可读;可写;可追加】

f = open("song",'r+',encoding="utf-8") #r+表示读写模式
for line in range(3):
 print(f.readline().strip())
f.write("-----------")

运行结果:



(2)w+   写读模式(应用不多):先创建一个文件然后再向里面写内容,注:写的内容从文件的最后面开始写入(写等同于追加)

f = open("song",'w+',encoding="utf-8")
f.write("-----------\n")
f.write("-----------\n")
f.write("-----------\n")

print(f.readline())
f.seek(14)
f.write("==========")
print(f.readline())
f.close()

运行结果:

(3).a+   追加读模式

12、"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)

应用:在网络传输只能用二进制模式进行传输;所有的二进制文件(如:视频)用二进制模式。

(1)二进制文件——读

f = open("song",'rb') #"b"表示处理二进制文件
for line in range(3):
 print(f.readline())

运行结果:

(2)二进制文件——写

f = open("song",'wb') #"b"表示处理二进制文件--写
f.write("Hello World\n".encode()) #需要将字符串编码成字节包(二进制格式)才能够写入
f.close()

运行结果:


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

(1)rU
(2)r+U

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python文件与目录操作技巧汇总》、《Python文本文件操作技巧汇总》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程

希望本文所述对大家Python程序设计有所帮助。

相关文章

  • Python Enum枚举类的定义及使用场景最佳实践

    Python Enum枚举类的定义及使用场景最佳实践

    枚举(Enum)是一种有助于提高代码可读性和可维护性的数据类型,允许我们为一组相关的常量赋予有意义的名字,在Python中,枚举类(Enum)提供了一种简洁而强大的方式来定义和使用枚举
    2023-11-11
  • python判定文件目录是否存在及创建多层目录

    python判定文件目录是否存在及创建多层目录

    这篇文章主要介绍了python判定文件目录是否存在及创建多层目录,文章通过os模块、try语句、pathlib模块善终模块展开详细的内容,感兴趣的朋友可以参考一下
    2022-06-06
  • Django中url的反向查询的方法

    Django中url的反向查询的方法

    本篇文章主要介绍了Django中url的反向查询的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • python 标准库原理与用法详解之os.path篇

    python 标准库原理与用法详解之os.path篇

    os.path模块主要用于文件的属性获取,在编程中经常用到,本文将带你熟悉这个模块并掌握它的用法,感兴趣的朋友跟小编来看看吧
    2021-10-10
  • Python实现的中国剩余定理算法示例

    Python实现的中国剩余定理算法示例

    这篇文章主要介绍了Python实现的中国剩余定理算法,结合实例形式分析了中国剩余定理的概念、原理及具体算法实现技巧,需要的朋友可以参考下
    2017-08-08
  • python如何获取tensor()数据类型中的值

    python如何获取tensor()数据类型中的值

    这篇文章主要介绍了python如何获取tensor()数据类型中的值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Flask框架单例模式实现方法详解

    Flask框架单例模式实现方法详解

    这篇文章主要介绍了Flask框架单例模式实现方法,结合实例形式分析了flask框架单例模式的4种实现方式与相关操作技巧,需要的朋友可以参考下
    2019-07-07
  • pyenv与virtualenv安装实现python多版本多项目管理

    pyenv与virtualenv安装实现python多版本多项目管理

    这篇文章主要介绍了pyenv与virtualenv安装实现python多版本多项目管理过程,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • Python爬虫 批量爬取下载抖音视频代码实例

    Python爬虫 批量爬取下载抖音视频代码实例

    这篇文章主要介绍了Python爬虫 批量爬取下载抖音视频代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • Python区块链创建Block Class教程

    Python区块链创建Block Class教程

    这篇文章主要为大家介绍了Python区块链创建Block Class教程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05

最新评论