python文件 I/O 操作

1、Python 中打开文件有哪些模式?
在这里插入图片描述

2、Python 中 read 、readline 和 readlines 的区别?
read:如果带参数size,从当前位置开始读取size个字节的内容;无参,把文件中的所有内容全部读取到内存中
readline:把文件中的一行读取到内存中,文件指针移到下一行
readlines:读取文件的所有行

3、大文件只需读取部分内容,或者避免读取时候内存不足的解决方法?

# 1、一次只读取部分内容,通过read指定size的大小来读取
import os
filename = "读取文件.txt"
file_size=os.stat(filename).st_size
f=open(filename, "r")
count_size=0
while count_size<file_size:
	if file_size-count_size>1024:
		size=1024
	else:
		size = file_size-count_size
	data = f.read(size)
	print(data)
	count_size+=size
f.close()
# 2、一次只读取一行内容
filename = "读取文件.txt"
with open(filename, "r") as f:
	for line in f:
		print(line)

4、什么是上下文?with 上下文管理器原理?
在编程中,可以理解为某一块片段代码的执行不能脱离于特点的环境独立运行

一般的文件操作,在操作完成之后,需要手动去关闭文件,用with上下文管理器后就不需要再手动区关闭文件,其实在管理器内部已经帮我们写了关闭文件的代码,上下文管理器内实现了两个方法,__ enter__()和__ exit__(),__ enter__()内帮我们做了文件的一些初始化工作,__ exit__()帮我们完成了文件关闭的收尾工作。

5、什么是全缓冲、行缓冲和无缓冲?
全缓冲:当缓冲区满时,才会把内容写入到磁盘中
行缓冲:当遇到换行符的时候,就会把缓冲区内的内容写入到磁盘中
无缓冲:直接把内容显示在界面上或写入磁盘,不经过缓冲区

6、什么是序列化和反序列化?JSON 序列化时常用的四个函数是什么?
序列化:按照某种规则,将内存中的数据保存到文件中,文件是一个字节序列
反序列化:把文件中的字节序列恢复到内存中并且还是原来的类型

dump、load、dumps、loads

7、JSON 中 dumps 转换数据时候如何保持中文编码?
dumps的参数ensure_ascii=False即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值