Python在读取文件时用的迭代器和readline有何区别

 我来答
就烦条0o
2016-09-08 · 知道合伙人软件行家
就烦条0o
知道合伙人软件行家
采纳数:33315 获赞数:46493
从事多年系统运维,喜欢编写各种小程序和脚本。

向TA提问 私信TA
展开全部
我想使用迭代器和readline的区别大概在于“读到文件末尾的时候,是否会抛出异常(是否用到了__next__方法),以及读取内容方式的差异”

每次调用readline,会前进到下一行进行读取,至文件末尾时返回空字符串,并不会抛出异常。而使用迭代器读至文件末尾时会抛出StopInteration异常

python有个迭代协议:含有__next__()方法的对象会反复调用该方法来返回数据流中的后继项,当没有可用数据时,产生一个StopInteration异常
迭代器是遵循迭代协议的物件。所有迭代工具内部在每次迭代时都会调用__next__(),并且捕捉StopIteration异常来确定何时离开。

for循环会将文件内容预加载到内存中,生成字符串列表。所以用这样的方式去读取文本文件,运行最快,写法也很简单。

而readline的优势在于,当我们只需要读取某行时,可以在readline的size参数里直接指定,并不需要加载整个文件,当然readline还有其他方便的内置函数,文档上都有一一列出
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式