先来个快速了解

想象一下,你有一本很厚的书,Python提供了三种不同的阅读方式:

  • read():一口气把整本书全部读完 (PS:一口气能读完一本书我只能说:天才+人才)
  • readline():每次只读一行,像用手指指着逐行阅读
  • readlines():也是读完全书,但是把每一行都分开整理好

下面咱们一个个详细讲解,配上代码例子,逐一给它击破。

一、read()方法 - 一次性读取全部内容

read()方法是最直接的文件读取方式,它会一次性把整个文件内容读取到一个字符串中。

# 示例代码
with open('C://Users/hp/Desktop/example.txt', 'r', encoding='utf-8') as file:
    content = file.read()
    print(content)
    print(f"读取的内容类型:{type(content)}")

特点:

  • 返回一个包含文件全部内容的字符串
  • 也可以指定读取的字符数,如read(100)表示只读取前100个字符
  • 简单粗暴,适合处理小文件,文件大小不大(比如几MB以内)
  • 需要一次性处理所有内容的情况,比如读取配置文件、小型文本文件等

注意事项:

千万别用read()读取大文件!比如几个GB的文件,这样会一下子吃掉你大量内存,可能导致程序崩溃

二、readline()方法 - 逐行读取的高手

readline()方法每次只读取文件的一行内容,非常适合处理大文件。

# 示例代码
with open('C://Users/hp/Desktop/example.txt', 'r', encoding='utf-8') as file:
    line = file.readline()
    while line:
        print(line.strip())  # strip()去除行尾换行符
        line = file.readline()

同样也是能够实现读取的。

我们可以点击file的readline()函数可以看一下:

特点:

  • 每次调用只读取一行,返回的是字符串类型。
  • 读取位置会记住,下次调用会读取下一行,需要逐行处理数据的场景
  • 内存友好,适合大文件,处理大型日志文件,内存有限的情况下处理大文件

实用技巧: 你可以结合while循环,逐行处理直到文件结束。

三、readlines()方法 - 返回行列表

readlines()方法读取整个文件,但返回的是一个列表,其中每个元素都是文件的一行内容。 我们先看看它的这个函数:

# 示例代码
with open('C://Users/hp/Desktop/example.txt', 'r', encoding='utf-8') as file:
    lines = file.readlines()
    print(f"总行数:{len(lines)}")
    for i, line in enumerate(lines, 1):
        print(f"第{i}行:{line.strip()}")

特点:

  • 返回包含所有行的列表,即使有空行,也是算一行的。适合需要随机访问文件的不同行,需要获取文件总行数
  • 每行末尾的换行符(n)会被保留
  • 可以方便地按行号访问特定行

注意事项:

和read()一样,readlines()也会一次性加载整个文件到内存,所以不适合处理非常大的文件

三种方法对比总结

为了更直观,我整理了一个对比表格:

方法返回类型内存占用适用场景特点
read()字符串小文件一次性读取全部内容
readline()字符串大文件逐行读取,内存效率高
readlines()列表中小文件,需要行级操作返回行列表,方便按行访问

如何选择?

知道了区别,怎么在实际中选择呢?我给你几个实用建议:

  1. 处理大文件(如日志文件):用readline()或者直接遍历文件对象,这样不会撑爆内存

  2. 处理小文件:三种都可以,根据需求选择。如果需要整个内容就用read(),如果需要按行处理就用readlines()

  3. 需要特定行:用readlines()获取列表后,可以直接通过索引访问特定行

  4. 逐行处理同时需要行号:可以用enumerate()函数:

    with open('file.txt', 'r') as file:
        for line_num, line in enumerate(file, 1):
            print(f"第{line_num}行:{line.strip()}")
    

暖心提示

  • 记得总是用with语句打开文件,这样可以自动处理文件关闭,避免资源泄露
  • 处理文本文件时注意编码问题,有时候需要指定encoding参数
  • 读取内容后经常需要用到strip()方法来去除首尾的空白字符和换行符

好了这就是ython中这三个文件读取方法的区别和用法。其实只要记住:小文件随便选,大文件用readline(),需要行列表用readlines(),就不会出错啦!

本站提供的所有下载资源均来自互联网,仅提供学习交流使用,版权归原作者所有。如需商业使用,请联系原作者获得授权。 如您发现有涉嫌侵权的内容,请联系我们 邮箱:alixiixcom@163.com