2010-08-22 9 views
8

En Python 2, los objetos de archivo tenían un método xreadlines() que devolvía un iterador que leía el archivo una línea a la vez. En Python 3, el método xreadlines() ya no existe, y realines() aún devuelve una lista (no un iterador). ¿Tiene Python 3 algo similar a xreadlines()?¿Qué sustituye xreadlines() en Python 3?

Yo sé que puedo hacer

for line in f: 

en lugar de

for line in f.xreadlines(): 

pero también me gustaría usar xreadlines() sin un bucle for:

print(f.xreadlines()[7]) #read lines 0 to 7 and prints line 7 
+1

Usted no puede * * El índice de un iterador. 'zip ([1,2,3], [4,5,6]) [0]' -> error. – kennytm

+0

@KennyTM Tienes razón. Eliminé la parte de mí que decía "puedes indexar un iterador". Pensé que podía indexar un iterador porque puedo hacer un rango (10) [7], pero eso no significa que pueda indexar un iterador. Gracias. – snakile

Respuesta

12

El objeto de archivo en sí mismo ya es 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' 

Use 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' 
1

cómo sobre esto (la expresión generador):

>>> f = open("r2h_jvs") 
>>> h = (x for x in f) 
>>> type(h) 
<type 'generator'>`