Foro de elhacker.net

Programación => Scripting => Mensaje iniciado por: Carloswaldo en 5 Enero 2010, 00:08 am



Título: Escribiendo strings en archivos (python 2.6)
Publicado por: Carloswaldo en 5 Enero 2010, 00:08 am
Bien pues tengo un código bastante simple, más o menos así:

Código
  1. import urllib
  2. a="http://diveintopython.org/html_processing/extracting_data.html"
  3. #Abrimos la url
  4. f = urllib.urlopen(a)
  5. s = f.read(10000)
  6. #Escribimos el resultado en un archivo
  7. log_file = open("log.txt", "w+" ,10000)
  8. log_file.write(s)
  9. f.close()
  10. raw_input()

Lo que hace es obtener el html de la url y guardarlo en un txt, o al menos eso es lo que debería hacer. El problema es que al ejecutar el script efectivamente se crea el archivo .txt pero solo se guarda una parte del html, y solo se guardará completo cuando se termine de ejecutar el script. Buscando he encontrado esto:

http://docs.python.org/library/stdtypes.html#file.write

Citar
file.write(str)
    Write a string to the file. There is no return value. Due to buffering, the string may not actually show up in the file until the flush() or close() method is called.

El .close() lo tengo y aún agregando un .flush() antes del .close() no me da los resultados que deseo. ¿Alguien sabe como puedo solucionar esto?


Título: Re: Escribiendo strings en archivos (python 2.6)
Publicado por: Novlucker en 5 Enero 2010, 00:15 am
Probaste sin usar buffer?

Código
  1. s = f.read()
  2. #Escribimos el resultado en un archivo
  3. log_file = open("log.txt", "w+")

Saludos


Título: Re: Escribiendo strings en archivos (python 2.6)
Publicado por: CaronteGold en 5 Enero 2010, 00:48 am
Probaste sin usar buffer?

Código
  1. s = f.read()
  2. #Escribimos el resultado en un archivo
  3. log_file = open("log.txt", "w+")

Saludos

 
   Si quitas el buffer, y haces print a " s ", se ve todo, pero luego al escribirlo en un .txt, aparece hasta poco antes del final, pero quedan lineas sin terminar...

  EDITO:


 Ya sé por qué es, tienes que cerrar tambien log_file, quedando  log_file.close()

  Saludos.


Título: Re: Escribiendo strings en archivos (python 2.6)
Publicado por: Carloswaldo en 5 Enero 2010, 04:07 am
Probaste sin usar buffer?

Código
  1. s = f.read()
  2. #Escribimos el resultado en un archivo
  3. log_file = open("log.txt", "w+")

Saludos

Sí, de hecho ese fue mi código original, pensé que indicando el número de bytes arreglaría el problema pero no fue así.

Ya sé por qué es, tienes que cerrar tambien log_file, quedando  log_file.close()

Funcionó perfecto. Gracias :D


Título: Re: Escribiendo strings en archivos (python 2.6)
Publicado por: Novlucker en 5 Enero 2010, 04:12 am
Ya sé por qué es, tienes que cerrar tambien log_file, quedando  log_file.close()
Funcionó perfecto. Gracias :D

Que ya no tenías el close()?, era justamente lo que ponía en la documentación oficial

Citar
file.write(str)
    Write a string to the file. There is no return value. Due to buffering, the string may not actually show up in the file until the flush() or close() method is called.
El .close() lo tengo y aún agregando un .flush() antes del .close() no me da los resultados que deseo. ¿Alguien sabe como puedo solucionar esto?


Título: Re: Escribiendo strings en archivos (python 2.6)
Publicado por: Carloswaldo en 5 Enero 2010, 04:13 am
Solo tenía el f.close(), me olvidé que también tenía que hacer log_file.close() :xD


Título: Re: Escribiendo strings en archivos (python 2.6)
Publicado por: Novlucker en 5 Enero 2010, 04:19 am
:xD ...

... tampoco esta de más decir que el importante es el file.close(), el de urllib se va a cerrar de cualquier manera, pero el file puede quedar bloqueado y no permitir acceder posteriormente :-\

Y bueno, solucionado entonces ....

Saludos


Título: Re: Escribiendo strings en archivos (python 2.6)
Publicado por: Carloswaldo en 5 Enero 2010, 04:28 am
Sip, a veces me trabo en tonterías xD Gracias a los 2.