当前位置: 首页 > article >正文

18 Python如何操作文件?

本篇是 Python 系列教程第 18 篇,更多内容敬请访问我的 Python 合集

1 打开文件

通常使用内置的 open(文件路径, 模式, encoding="utf-8")函数。

  • 文件路径:可以是相对路径或绝对路径。
  • 模式:(可选)决定了文件打开后如何处理文件。
  • encoding:(可选)编码方式。

常见的模式有:

  • ‘r’ (默认):只读模式,如果文件不存在,则会引发 FileNotFoundError。
  • ‘w’:写入模式,如果文件存在则会清空内容再写入,如果文件不存在则创建新文件。
  • ‘a’:追加模式,在文件末尾追加内容,如果文件不存在则创建新文件。
  • ‘b’:二进制模式,用于处理二进制文件(如图像、音频等)。
  • ‘+’:更新模式,用于同时进行读写操作。

可以将这些模式组合起来使用,例如:

  • ‘rb’:以二进制模式读取文件。
  • ‘wb’:以二进制模式写入文件。
  • ‘ab’:以二进制模式追加内容到文件。
  • ‘r+’:读写模式,可以读取和写入文件。
  • ‘w+’:写入并读取模式,先写入后读取。
  • ‘a+’:追加并读取模式,先追加后读取。

2 文件读取

如果open()函数执行成功,会返回一个文件对象。后续可以对这个对象进行读取或写入操作。

f = open('./data.txt', 'r', encoding='utf-8')

文件对象有个read()方法,会一次性读取文件里的所有内容,并返回字符串格式。

实例:

file = open('data.txt', 'r', encoding="utf-8")
print(file.read())

注意:

  • 如果调用过read()后再次调用,会返回空,因为程序会记录文件被读取的位置,第一次read()时已经读到文件末尾,第二次read()后面就没有内容了。
  • 大文件也不适合用read(),因为会一次性读取文件的所有内容,可能挤爆内存。

上面说大文件不适合用read(),那有别的替换方案吗?当然有,解决方案就是一次性只读取部分内容,如:

  • read()传一个数字参数如read(1024),表示一次读多少字节,下次再调用read(1024)时就会继续从上次的结束位置读取。
  • 使用readline(),此方法一次只会读取一行内容,是根据换行符来判断本行结尾的,而且换行符也会被当做内容的一部分被读取。

上面的两种方式可搭配while循环来用,另外还有一个readlines()方法,会一次性返回所有行,组成一个字符串列表,一般搭配for循环使用。

3 文件写入

调用open()函数时第二个参数传wa就可以进行文件写入操作。这里说明一点,如果第二个参数是r,且文件不存在就会报FileNotFoundError错误,但是wa就不会报错,它会自动创建一个文件。

在打开或创建文件之后就可以调用文件对象的write()方法进行写入操作了。

示例:

with open('data.txt', 'w', encoding="utf-8") as file:
    file.write("hello ")
    file.write("python")

data.txt内容:

hello python

注意write()方法并不会自动换行,需要手动添加换行符,如把代码改成file.write("hello\n"),data.txt就会变成:

hello
python

如果我们使用w模式,文件就只能写入不能读取,如果我们想先读取再写入,可以用r+模式

4 关闭文件

文件操作完毕后,文件对象需要调用一个close()方法关闭文件释放资源。

每次文件操作完毕后都应该关闭文件,但是有可能会粗心忘记关闭,怎么办呢?我们可以在调用open()函数打开文件的时候使用with关键字,然后用as指定读取到的文件,这样在with代码块执行完后文件就会被自动关闭了,实例:

# 使用 with 语句来读取文件
with open('data.txt', 'r', encoding='utf-8') as file:
    for line in file.readlines():
        print(line.strip())

http://www.kler.cn/a/301877.html

相关文章:

  • STM32寄存器结构体详解
  • Python 中常用的格式符号
  • [Codesys]常用功能块应用分享-BMOV功能块功能介绍及其使用实例说明
  • Spark RDD sortBy算子什么情况会触发shuffle
  • Python小试牛刀:第一次爬虫,获取国家编码名称
  • 【2025最新计算机毕业设计】基于SpringBoot+Vue电脑在线装机指南教程网站【源码+文档】
  • docker和docker-compose安装脚本
  • Ajax 揭秘:异步 Web 交互的艺术
  • Transformer学习(1):注意力机制
  • Linux——网络基础Socket编程
  • 10个Python办公自动化案例
  • Unity3D 服务器AStar寻路客户端位置同步显示验证详解
  • C语言学习笔记
  • 运维学习————运维日志分析系统es——Elasticsearch
  • GORM安全-保护你的应用免受SQL注入攻击
  • C语言:乘法口诀表的一些实现方法
  • springboot基础-logback组件配置使用
  • 2024年9月12日(k8s环境及测试 常用命令)
  • 康谋分享 | 汽车仿真与AI的结合应用
  • 1.SpringCloud与SpringCloud Alibaba
  • Java面试篇基础部分-Java中的异常以及异常处理
  • 初识爬虫3
  • 【区块链通用服务平台及组件】信息数据流转验真技术研究项目 | FISCO BCOS应用案例
  • HCIA--实验十一:单区域OSPF路由实验
  • 基于SpringBoot+Vue+MySQL的垃圾分类回收管理系统
  • 【菜菜的sklearn机器学习】(2)回归树