Pregunta

En Python 2, objetos de archivo tenido un xreadlines () método que devuelve un iterador que leer el archivo de una línea a la vez. En Python 3, los xreadlines () método ya no existe, y realines () todavía devuelve una lista (no un iterador). ¿El Python 3 tiene algo similar a xreadlines ()?

Sé que puedo hacer

for line in f:

en lugar de

for line in f.xreadlines():

Pero también me gustaría a xreadlines uso de () sin un bucle:

print(f.xreadlines()[7]) #read lines 0 to 7 and prints line 7
¿Fue útil?

Solución

El propio objeto de archivo ya es un iterable.

>>> f = open('1.txt')
>>> f
<_io.TextIOWrapper name='1.txt' encoding='UTF-8'>
>>> next(f)
'1,B,-0.0522642316338,0.997268450092\n'
>>> next(f)
'2,B,-0.081127897359,2.05114559572\n'

Uso itertools.islice para obtener un elemento arbitrario de un iterable.

>>> f.seek(0)
0
>>> next(islice(f, 7, None))
'8,A,-0.0518101108474,12.094341554\n'

Otros consejos

¿qué tal esto (expresión generador):

>>> f = open("r2h_jvs")
>>> h = (x for x in f)
>>> type(h)
<type 'generator'>`
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top