Python - 文件读取read()、readline()、readlines()区别
前言
读取文件的三个方法:read()、readline()、readlines()。均可接受一个方法参数用以限制每次读取的数据量,但通常不使用
read()
优点:读取整个文件,将文件内容放到一个字符串变量中。
劣势:如果文件非常大,尤其是大于内存时,无法使用read()方法。
总结:不适用于读取大文件
简单代码
f = open('test/gbk.txt', 'r+', encoding='utf-8') print(f.read())
测试结果
123 456 789 @#$%
readline()
优点:readline()方法每次读取一行;返回的是一个字符串对象,保存当前行的内存,不占用内存
缺点:比readlines慢得多
简单代码
# 读取一行 f = open('test/gbk.txt', 'r+', encoding='utf-8') print("读取一行 ====") line = f.readline() while line: # 打印当前文件指针的位置 print("文件指针:", f.tell()) print("行内容:", line) line = f.readline()
测试结果
读取一行 ==== 文件指针: 7 行内容: tests 文件指针: 12 行内容: 123 文件指针: 17 行内容: 456 文件指针: 22 行内容: 789 文件指针: 28 行内容: 菠萝
包含知识点
- 当你每次调用readline()方法时,你的文件指针就会指向当前行尾部,一个换行符 \n 占两位,一个中文也是
- 读取到最后一行之后再调用readline()就会返回空,结束循环
readlines()
特点:一次性读取整个文件;自动将文件内容分析成一个行的列表
简单代码
# 读取多行 f = open('test/gbk.txt', 'r+', encoding='utf-8', errors='ignore') print("读取多行 ====") print(f.readlines())
测试结果
['tests\n', '123\n', '456\n', '789\n', '菠萝']
包含知识点
- readlines()读取所有行然后把它们作为一个字符串列表返回
- 返回的每一行内容包含换行符
标签:
Python
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具