通过实例解析Python文件操作实现步骤


Posted in Python onSeptember 21, 2020

当程序运行时,变量是保存数据的好方法,但变量、序列以及对象中存储的数据是暂时的,程序结束后就会丢失,如果希望程序结束后数据仍然保持,就需要将数据保存到文件中。

Python 提供了内置的文件对象,以及对文件、目录进行操作的内置模块,通过这些技术可以很方便地将数据保存到文件(如文本文件等)中。

一、文件的概念

在计算机中,文件是以二进制的方式保存在磁盘上的。

文件分为文本文件和二进制文件。

1、文本文件

可以使用文本编辑软件查看,本质上还是二进制文件,例如:python 的源程序。

2、二进制文件

保存的内容不是给人直接阅读的,而是提供给其他软件使用的。例如:图片文件、音频文件、视频文件等等,二进制文件不能使用文本编辑软件查看。

Python 中,对文件的操作有很多种,常见的操作包括创建、删除、修改权限、读取、写入等,这些操作可大致分为以下 2 类:

删除、修改权限:作用于文件本身,属于系统级操作。
写入、读取:是文件最常用的操作,作用于文件的内容,属于应用级操作。

二、文件的基本操作

1、操作文件的步骤

文件的应用级操作可以分为以下 3 步,每一步都需要借助对应的函数实现:

打开文件:使用 open() 函数,该函数会返回一个文件对象;

对已打开文件做读/写操作:读取文件内容可使用 read()、readline() 以及 readlines() 函数;向文件中写入内容,可以使用 write() 函数。

关闭文件:完成对文件的读/写操作之后,最后需要关闭文件,可以使用 close() 函数。

2、打开文件的方式

在 Python 中,如果想要操作文件,首先需要创建或者打开指定的文件,并创建一个文件对象,而这些工作可以通过内置的 open() 函数实现。

语法如下:

  • file = open(file_name [, mode='r' [ , buffering=-1 [ , encoding = None ]]])
  • file:表示要创建的文件对象。
  • file_name:要创建或打开文件的文件名称。
  • mode:用于指定文件的打开模式。默认以只读(r)模式打开文件。
  • buffering:用于指定对文件做读写操作时,是否使用缓冲区。
  • encoding:手动设定打开文件时所使用的编码格式,不同平台的 ecoding 参数值也不同,以 Windows 为例,其默认为 cp936(实际上就是 GBK 编码)。

打开文件的常用模式

模式 说明
r 以只读方式打开文件。文件的指针将会放在文件的开头,这是默认模式。如果文件不存在,抛出异常
w 以只写方式打开文件。如果文件存在会被覆盖。如果文件不存在,创建新文件
a 以追加方式打开文件。如果该文件已存在,文件指针将会放在文件的结尾。如果文件不存在,创建新文件进行写入
r+ 以读写方式打开文件。文件的指针将会放在文件的开头。如果文件不存在,抛出异常
w+ 以读写方式打开文件。如果文件存在会被覆盖。如果文件不存在,创建新文件
a+ 以读写方式打开文件。如果该文件已存在,文件指针将会放在文件的结尾。如果文件不存在,创建新文件进行写入

文件打开方式

通过实例解析Python文件操作实现步骤

open()是否需要缓冲区

通常情况下、建议大家在使用 open() 函数时打开缓冲区,即不需要修改 buffing 参数的值。

如果 buffing 参数的值为 0(或者 False),则表示在打开指定文件时不使用缓冲区;如果 buffing 参数值为大于 1 的整数,该整数用于指定缓冲区的大小(单位是字节);如果 buffing 参数的值为负数,则代表使用默认的缓冲区大小。

目前为止计算机内存的 I/O 速度仍远远高于计算机外设(例如键盘、鼠标、硬盘等)的 I/O 速度,如果不使用缓冲区,则程序在执行 I/O 操作时,内存和外设就必须进行同步读写操作,也就是说,内存必须等待外设输入(输出)一个字节之后,才能再次输出(输入)一个字节。这意味着,内存中的程序大部分时间都处于等待状态。

而如果使用缓冲区,则程序在执行输出操作时,会先将所有数据都输出到缓冲区中,然后继续执行其它操作,缓冲区中的数据会有外设自行读取处理;同样,当程序执行输入操作时,会先等外设将数据读入缓冲区中,无需同外设做同步读写操作。

3、read 方法 —— 读取文件

read 方法可以一次性读入并返回文件的所有内容。

read() 函数的基本语法格式如下:

file.read([size])

其中,file 表示已打开的文件对象;size 作为一个可选参数,用于指定一次最多可读取的字符(字节)个数,如果省略,则默认一次性读取所有内容。

如果忘记关闭文件,会造成系统资源消耗,而且会影响到后续对文件的访问。

注意:read 方法执行后,会把文件指针移动到文件的末尾。

示例:

# 1. 打开 - 文件名需要注意大小写
file = open("README")

# 2. 读取
text = file.read()
print(text)

# 3. 关闭
file.close()

在开发中,通常会先编写打开和关闭的代码,再编写中间针对文件的读/写操作!

4、按行读取文件内容

read 方法默认会把文件的所有内容一次性读取到内存。

如果文件太大,对内存的占用会非常严重。

readline 方法可以一次读取一行内容,包含最后的换行符“\n”。方法执行后,会把文件指针移动到下一行,准备再次读取。

file.readline([size])

其中,file 为打开的文件对象;size 为可选参数,用于指定读取每一行时,一次最多读取的字符(字节)数。

读取大文件的正确姿势

# 打开文件
file = open("README")
while True:
  # 读取一行内容
  text = file.readline()
  # 判断是否读到内容
  if not text:
    break
  # 每读取一行的末尾已经有了一个 `\n`
  print(text, end="")
# 关闭文件
file.close()

示例:

小文件复制

# 1. 打开文件
file_read = open("README")
file_write = open("README[复件]", "w")

# 2. 读取并写入文件
text = file_read.read()
file_write.write(text)

# 3. 关闭文件
file_read.close()
file_write.close()

大文件复制

# 1. 打开文件
file_read = open("README")
file_write = open("README[复件]", "w")

# 2. 读取并写入文件
while True:
  # 每次读取一行
  text = file_read.readline()

  # 判断是否读取到内容
  if not text:
    break

  file_write.write(text)

# 3. 关闭文件
file_read.close()
file_write.close()

对于按行来读取文件,还有一个 readlines() 函数。

readlines() 函数用于读取文件中的所有行,它和调用不指定 size 参数的 read() 函数类似,只不过该函数返回是一个字符串列表,其中每个元素为文件中的一行内容。

和 readline() 函数一样,readlines() 函数在读取每一行时,会连同行尾的换行符一块读取。

5、文件指针

文件指针可以理解为一个标记,它标记从哪个位置开始读取数据。

第一次打开文件时,通常文件指针会指向文件的开始位置,当执行了 read 方法后,文件指针默认情况下会移动到读取内容的末尾。

如果执行了一次 read 方法,读取了所有内容,那么再次调用 read 方法,还能够获得到内容吗?

答案是不能,第一次读取之后,文件指针移动到了文件末尾,再次调用不会读取到任何的内容。

# 首先在 README 文件中写了8个1
# 1. 打开 - 文件名需要注意大小写
file = open("README")
# 2. 读取
text = file.read()
print(text)
text = file.read()
print("-" * 10)
print(text)
# 3. 关闭
file.close()
#1111111
#----------
#

6、向文件中写入数据

Python 中的文件对象提供了 write() 函数,可以向文件中写入指定内容。该函数的语法格式如下:

file.write(string)
在写入文件完成后,一定要调用 close() 函数将打开的文件关闭,否则写入的内容不会保存到文件中。

这是因为,当我们在写入文件内容时,操作系统不会立刻把数据写入磁盘,而是先缓存起来,只有调用 close() 函数时,操作系统才会保证把没有写入的数据全部写入磁盘文件中。

写入文件示例:

# 打开文件
f = open("README", "w")

f.write("hello python!\n")
f.write("今天天气真好")

# 关闭文件
f.close()

如果向文件写入数据后,不想马上关闭文件,也可以调用文件对象提供的 flush() 函数,它可以实现将缓冲区的数据写入文件中。

f = open("a.txt", 'w')
f.write("写入一行新数据")
f.flush()

三、文件/目录的常用管理操作

在终端 / 文件浏览器中可以执行常规的文件 / 目录管理操作,例如:创建、重命名、删除、改变路径、查看目录内容等等。

在 Python 中,如果希望通过程序实现上述功能,需要导入 os 模块。

1、文件操作

方法名 说明 示例
rename 重命名文件 os.rename(源文件名, 目标文件名)
remove 删除文件 os.remove(文件名)

2、目录操作

方法名 说明 示例
listdir 目录列表 os.listdir(目录名)
mkdir 创建目录 os.mkdir(目录名)
rmdir 删除目录 os.rmdir(目录名)
getcwd 获取当前目录 os.getcwd()
chdir 修改工作目录 os.chdir(目标目录)

文件或者目录的操作都支持相对路径和绝对路径。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现测试磁盘性能的方法
Mar 12 Python
在Python的Bottle框架中使用微信API的示例
Apr 23 Python
Python安装第三方库的3种方法
Jun 21 Python
Python和C/C++交互的几种方法总结
May 11 Python
python如何派生内置不可变类型并修改实例化行为
Mar 21 Python
Matplotlib 生成不同大小的subplots实例
May 25 Python
解决Django的request.POST获取不到内容的问题
May 28 Python
Python异常处理知识点总结
Feb 18 Python
numpy concatenate数组拼接方法示例介绍
May 27 Python
决策树剪枝算法的python实现方法详解
Sep 18 Python
利用setuptools打包python程序的方法步骤
Jan 18 Python
python实现canny边缘检测
Sep 14 Python
python Paramiko使用示例
Sep 21 #Python
Python引入多个模块及包的概念过程解析
Sep 21 #Python
python 偷懒技巧——使用 keyboard 录制键盘事件
Sep 21 #Python
简单了解python关键字global nonlocal区别
Sep 21 #Python
PIP和conda 更换国内安装源的方法步骤
Sep 21 #Python
python 字符串格式化的示例
Sep 21 #Python
基于python判断字符串括号是否闭合{}[]()
Sep 21 #Python
You might like
ThinkPHP5实现作业管理系统中处理学生未交作业与已交作业信息的方法
2016/11/12 PHP
thinkphp实现附件上传功能
2017/05/26 PHP
PHP实现微信红包金额拆分试玩的算法示例
2018/04/07 PHP
PHP单例模式应用示例【多次连接数据库只实例化一次】
2018/12/18 PHP
高性能Javascript笔记 数据的存储与访问性能优化
2012/08/02 Javascript
缓动函数requestAnimationFrame 更好的实现浏览器经动画
2012/12/07 Javascript
将文本输入框内容加入表中的js代码
2013/08/18 Javascript
JavaScript生成GUID的多种算法小结
2013/08/18 Javascript
使用ngView配合AngularJS应用实现动画效果的方法
2015/06/19 Javascript
jquery UI Datepicker时间控件的使用方法(基础版)
2015/11/07 Javascript
vue2.0使用Sortable.js实现的拖拽功能示例
2017/02/21 Javascript
Angular2入门--架构总览
2017/03/29 Javascript
详解Vue结合后台的列表增删改案例
2018/08/21 Javascript
angularjs的单选框+ng-repeat的实现方法
2018/09/12 Javascript
解决layer.prompt无效的问题
2019/09/24 Javascript
layer弹出层倒计时关闭的实现方法
2019/09/27 Javascript
ant design vue datepicker日期选择器中文化操作
2020/10/28 Javascript
js实现电灯开关效果
2021/01/19 Javascript
[04:00]DOTA2解说界神雕侠侣 CJ第四天谷子现场过生日
2013/07/30 DOTA
[03:14]辉夜杯主赛事 12月25日每日之星
2015/12/26 DOTA
python正则表达式match和search用法实例
2015/03/26 Python
Python实现的最近最少使用算法
2015/07/10 Python
Python3使用pandas模块读写excel操作示例
2018/07/03 Python
Python3转换html到pdf的不同解决方案
2019/03/11 Python
PHP统计代码行数的小代码
2019/09/19 Python
python多进程(加入进程池)操作常见案例
2019/10/21 Python
Python守护进程实现过程详解
2020/02/10 Python
python实现遍历文件夹图片并重命名
2020/03/23 Python
python输入中文的实例方法
2020/09/14 Python
理工科学生的自我评价
2013/12/15 职场文书
餐厅总经理岗位职责
2013/12/31 职场文书
我爱我校演讲稿
2014/05/21 职场文书
党的群众路线教育实践活动自我剖析材料
2014/10/08 职场文书
2016年劳模先进事迹材料
2016/02/25 职场文书
应用最多的公文《通知》如何写?
2019/04/02 职场文书
python爬取企查查企业信息之selenium自动模拟登录企查查
2021/04/08 Python