Leer archivo de texto con Go

En este post voy a explicar cómo leer el contenido de un archivo de texto usando Go. Es decir, obtener todo el contenido del archivo y pasarlo a una variable de tipo cadena o string.

De esta manera, se podrá imprimir el contenido de un archivo fácilmente. Se especifican dos formas: una en donde se lee todo el contenido de un archivo, y otra en donde, a través de un búfer, se leen fragmentos o bytes del archivo; especialmente cuando se trata de archivos o ficheros grandes.

El archivo de texto

Para ejemplificar este tutorial, el archivo de texto que se ocupará es este:

El mismo contiene tabulaciones, saltos de línea y texto en general. De cualquier manera, el mismo es incluido en cada gist abajo.

Leer todo el archivo de texto dentro de una cadena usando Go

El método más fácil de implementar para leer un archivo de texto en Go es leerlo todo en un string. Esto no es óptimo cuando se tienen archivos grandes; pues todo el contenido será puesto en la RAM. En fin, si el archivo es relativamente pequeño, no pasa nada.

Aquí está el código:

Para leer todo el contenido se utiliza <span>ioutil.</span><span class="pl-c1">ReadFile</span>(nombreArchivo) (fuente); el cual regresa un slice de bytes. Luego se convierte a cadena con string(bytesLeidos) y más tarde se puede imprimir o hacer cualquier cosa.

Se puede probar el código en vivo:

Obtener contenido de un archivo trozo por trozo usando Go

Este método es el más eficaz cuando se leen grandes archivos (incluso de gigabytes). Aquí está el código:

Primero se reserva un búfer, que en realidad es un slice de bytes. Su longitud está dada en bytes, la cual puede ser cambiada en la constante <span>TamanioBufer</span>. En términos generales, cada byte es un carácter del archivo de texto, por lo que si se desea leer carácter por carácter, el búfer debería ser de 1 byte.

Cuando se ha terminado la lectura, se lanza un error de tipo io.EOF; y ahí se acaba el ciclo. Dentro del mismo también se está comprobando si no hay algún error distinto al del fin de línea.

No importa si el búfer es más grande que los datos leídos, por eso es que se utiliza a bufer[:bytesLeidos] para cortar el slice desde 0 hasta el número de bytes leídos.

Igualmente el código se puede probar aquí:

Encantado de ayudarte


Estoy disponible para trabajar en tu proyecto, modificar el programa del post o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.

No te pierdas ninguno de mis posts

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.

Dejar un comentario