python文件缓冲

在这里插入图片描述

在这里插入图片描述
观察缓冲

import time
def main():
    # w代表输出 文件不存在时,自动创建,创建成功之后写入数据
    file =  open("E:\\test.txt", mode="w",encoding="UTF-8",buffering=1);
    file.write("奥特曼打小怪兽");
    # 刷新缓冲
    # file.write("\n");
    # 休眠10秒,观察数据在缓冲中还未写入到文件
    time.sleep(10);
if __name__ == '__main__':
    main();

使用flush强制刷新缓冲

def main():
    # w代表输出 文件不存在时,自动创建,创建成功之后写入数据
    file =  open("E:\\test.txt", mode="w",encoding="UTF-8",buffering=1);
    file.write("奥特曼打小怪兽");
    # 刷新缓冲
    file.flush()
if __name__ == '__main__':
    main();

每当使用close()方法关闭文件流的时候,默认情况下也会调用flush()方法进行缓冲区的清空处理,强制性输出

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中,缓冲区是指用于临时存储数据的内存区域,通常用于提高I/O操作的效率。Python中的文件对象默认是带有缓冲区的,读写文件时,数据会先被读入或写入缓冲区,然后再一次性地写入或读出文件。这种方式可以减少I/O操作的次数,提高程序的性能。 Python中的缓冲区分为全缓冲、行缓冲和无缓冲三种方式: - 全缓冲:当缓冲区满时才进行I/O操作,例如使用`open()`函数打开文件时,设置`buffering`参数为大于1的整数,则会使用全缓冲方式。 - 行缓冲:当输入输出遇到换行符时才进行I/O操作,例如在终端输入时,就是使用行缓冲方式。 - 无缓冲:每次读写都进行I/O操作,例如使用`open()`函数打开文件时,设置`buffering`参数为0,则会使用无缓冲方式。 在Python中,可以使用`sys.stdout.flush()`强制刷新缓冲区,将缓冲区中的数据写入到文件中。另外,可以使用`io`模块提供的`BufferedWriter`、`BufferedReader`、`BufferedRandom`等类,来创建带缓冲区的文件对象,从而实现更高效的I/O操作。例如: ```python import io # 创建带缓冲区的输出文件对象 with io.BufferedWriter(open('output.txt', 'wb')) as f: f.write(b'Hello, world!') # 创建带缓冲区的输入文件对象 with io.BufferedReader(open('input.txt', 'rb')) as f: data = f.read() ``` 以上代码中,`BufferedWriter`和`BufferedReader`类的构造函数都有一个可选参数`buffer_size`,可以用来设置缓冲区的大小。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值