Leer archivo de texto con Go

Publicado por parzibyte en

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 ioutil.ReadFile(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 TamanioBufer. 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í:


parzibyte

He trabajado por más de 4 años en el desarrollo de software con experiencia en Java, PHP, JavaScript, HTML, Node.JS, Python, Android y Go. También he trabajado con bases de datos SQL como MySQL y SQLite, así como con bases de datos NoSQL usando MongoDB.Soy bueno utilizando algunos frameworks y herramientas como Firebase, jQuery, AngularJS, VueJS, CodeIgniter, Laravel, BulmaCSS, Bootstrap y Electron.Otros términos que conozco son: Arduino, GraphQL, API's, REST, AJAX, PouchDB, CouchDB, Experiencia de usuario, buenas prácticas de programación, Webpack, NPM, Administración de servidores y programación de scriptsLa plataforma en la que tengo más experiencia es la web, pero en mis ratos libres realizo unos pequeños ejercicios en C# y C.Estoy aquí para ayudarte a resolver tus problemas de programación y depuración :-)

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

A %d blogueros les gusta esto: