Does readlines() return a list or an iterator in Python 3? Does readlines() return a list or an iterator in Python 3? python python

Does readlines() return a list or an iterator in Python 3?


The readlines method doesn't return an iterator in Python 3, it returns a list

Help on built-in function readlines:readlines(...)    Return a list of lines from the stream.

To check, just call it from an interactive session - it will return a list, rather than an iterator:

>>> type(f.readlines())<class 'list'>

Dive into Python appears to be wrong in this case.


xreadlines has been deprecated since Python 2.3 when file objects became their own iterators. The way to get the same efficiency as xreadlines is instead of using

 for line in f.xreadlines():

you should use simply

 for line in f:

This gets you the iterator that you want, and helps to explain why readlines didn't need to change its behaviour in Python 3 - it can still return a full list, with the line in f idiom giving the iterative approach, and the long-deprecated xreadlines has been removed completely.


Like this:

Python 3.1.2 (r312:79149, Mar 21 2010, 00:41:52) [MSC v.1500 32 bit (Intel)] on win32Type "help", "copyright", "credits" or "license" for more information.>>> f = open('/junk/so/foo.txt')>>> type(f.readlines())<class 'list'>>>> help(f.readlines)Help on built-in function readlines:readlines(...)    Return a list of lines from the stream.    hint can be specified to control the number of lines read: no more    lines will be read if the total size (in bytes/characters) of all    lines so far exceeds hint.>>>


Others have said as much already, but just to drive the point home, ordinary file objects are their own iterators. So having readlines() return an iterator would be silly, because it would just return the file you called it on. You can use a for loop to iterate over a file, like Scott said, and you can also pass them straight to itertools functions:

from itertools import islicef = open('myfile.txt')oddlines = islice(f, 0, None, 2)firstfiveodd = islice(oddlines, 5)for line in firstfiveodd:  print(line)