详细分析Python中的read()、readline、readlines()方法

前言

在Python中,可以使用open()函数来打开文件并读取其中的内容,然后使用不同的方法来处理文件内容

文件内容如下:

This is a sample file.
It contains some text.
码农研究僧

1. read()

read()函数:从文件中读取指定数量的字节,默认情况下会读取整个文件

  • 如果指定了可选参数size,则读取size个字节的内容
  • 如果到达文件末尾,则返回空字符串

示例:

with open('example.txt', 'r') as file:
    content = file.read()
    print(content)

在这个示例中,read()方法会读取整个文件的内容,如果文件涉及中文,需要进行编码,否则会出现如下错误:

在这里插入图片描述

这个错误通常表示正在尝试解码一个无效的字节序列,而指定的解码器无法处理这种情况。这通常发生在尝试使用错误的字符编码解码文件时,例如在Windows上,默认的字符编码是GBK,但是如果文件实际上是使用其他字符编码(例如UTF-8)保存的,就会导致解码错误

要解决这个问题,尝试指定正确的字符编码来打开文件,例如UTF-8。这可以通过在open()函数中传递encoding参数来实现

示例如下:

with open('example.txt', 'r', encoding='utf-8') as file:
    content = file.read()
    print(content)

截图如下:

在这里插入图片描述

因为没有指定size参数

如果指定了size参数的示例:

with open('example.txt', 'r') as file:
    partial_content = file.read(10)  
    print(partial_content) # 输出This is a 

2. readline()

readline()函数:从文件中读取一行内容

示例:

with open('example.txt', 'r', encoding='utf-8') as file:
    line = file.readline()
    while line:
        print(line.strip())  # 去除行末尾的换行符
        line = file.readline()

在这个示例中,readline()方法会逐行读取文件内容,并打印每一行

通过strip()方法去除每行末尾的换行符,以保持输出的整洁

with open('example.txt', 'r', encoding='utf-8') as file:
    lines_to_read = 1
    for _ in range(lines_to_read):
        line = file.readline()
        if line:
            print(line.strip())  # 去除行末尾的换行符
        else:
            break

3. readlines()

readlines()函数:从文件中读取所有行,并将其放入一个列表中,每行作为列表的一个元素

with open('example.txt', 'r', encoding='utf-8') as file:
    lines = file.readlines()
    for line in lines:
        print(line)

4. 彩蛋

以上这些方法的选择取决于需要处理的文件内容和处理方式

如果文件较大,使用readline()readlines()方法可能更有效,因为它们逐行读取文件,而read()会一次性读取整个文件到内存中

总的来说:

  • 使用read():输出整个文件内容
  • 使用readline():逐行输出文件内容
  • 使用readlines():将文件内容存储在列表中,并逐行输出

另外补充一下with as的概念

在Python中,使用with语句可以自动管理资源,包括文件

with语句创建了一个上下文管理器,它在代码块执行前调用__enter__()方法,在代码块执行后调用__exit__()方法。对于文件对象,with语句会自动调用file.close()方法,因此在with代码块结束时,文件会自动关闭,无需手动调用close()方法来释放资源

with语句的作用:主要是简化资源管理的代码,使代码更清晰、更易读,并且确保资源的正确释放,即使在发生异常的情况下也能正确处理

with语句的神奇之处在于它能够自动管理资源的生命周期,无需程序员手动干预

这种自动化管理大大减少了程序中出现资源泄露或遗忘关闭资源的可能性,提高了代码的健壮性和可靠性

  • 23
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
`readline()` 是 Python 文件对象的一个方法,用于读取文件的一行数据。其语法如下: ```python file.readline(size=-1) ``` 其,`file` 是要读取的文件对象,`size` 是可选参数,用于指定要读取的最大字节数。 当 `size` 为负数或者未指定时,`readline()` 方法会读取文件的一行数据,并返回一个字符串。如果已经到达文件的末尾,则返回一个空字符串 `''`。例如,对于以下文件: ``` hello world ``` 执行以下代码: ```python file = open('file.txt', 'r') print(file.readline()) print(file.readline()) print(file.readline()) file.close() ``` 会输出以下结果: ``` hello world ``` 需要注意的是,`readline()` 方法会保留行末的换行符(`\n`),因此在打印输出时会出现空行。如果不希望保留换行符,可以使用 `strip()` 方法去除。例如,将上面的代码改为: ```python file = open('file.txt', 'r') print(file.readline().strip()) print(file.readline().strip()) print(file.readline().strip()) file.close() ``` 则会输出以下结果: ``` hello world ``` 如果指定了 `size` 参数,则 `readline()` 方法会读取指定字节数的数据,如果读取的数据不足指定的字节数,则返回读取到的所有数据。例如,执行以下代码: ```python file = open('file.txt', 'r') print(file.readline(3)) print(file.readline(3)) print(file.readline(3)) file.close() ``` 会输出以下结果: ``` hel lo wor ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农研究僧

你的鼓励将是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值