En este post explicaré cómo trabajar con CSV desde el lenguaje de programación Ruby. Vamos a leer un archivo CSV (archivo separado por comas u otro delimitador) y también a escribir contenido a un nuevo archivo.

Leer y escribir archivos CSV con Ruby

Leer y escribir archivos CSV con Ruby

Nota: la foto del código fue tomada con Polacode y la marca de agua colocada con WaterPy.

Te invito a leer antes cómo escribir y leer archivos en Ruby, para que no te confundas al leer los ejercicios aquí presentados.

Trabajar con archivos CSV en Ruby

Para leer y escribir archivos CSV con Ruby se usa la clase o módulo csv; se podría hacer a mano pero no hay necesidad de reinventar la rueda.

Aquí veremos cómo hacer ambas operaciones, algunas con clases y otras “simples” pero lo importante es ver cómo se abre el archivo y se le pasan las cosas que se escriben.

Escribir archivo CSV con Ruby

Para escribir a un archivo, una vez abierto, se le pasan los datos en forma de arreglo; así:

archivo << ["Un dato", "Otro dato", "Aquí más datos..."]

En cada llamada se creará una nueva fila o línea.

Eso puede ser llamado en cualquier lugar. En el siguiente ejemplo escribimos los detalles de un producto dentro de un ciclo.

Por cierto, el archivo de productos.csv es el resultado de escribir a través de Ruby. Como lo dije, lo importante es la línea en donde se escribe directamente; lo demás es el ciclo y la apertura del archivo.

Leer CSV con Ruby

Una vez que ya escribimos, vamos a leer. Con Ruby es muy fácil leer un archivo CSV sin importar el contenido que tenga.

Lo digo de nuevo, en el ejemplo se usa una clase pero lo importante es la parte en donde se obtiene a la variable fila en cada iteración; esa fila es un arreglo indexado por números; es decir, el elemento 0 tiene el primer valor, el elemento 1 el segundo y así sucesivamente.

Algo que se debe notar es que implementamos el método to_s de la clase Producto, de este modo al imprimir con puts se pueden imprimir como texto formateado y bonito.

Lo digo de nuevo, no es necesario esto de las clases, ya que obtenemos la fila como arreglo en cada iteración.

Probar y descargar ejemplos

Puedes descargar los ejemplos así como los archivos CSV, instala Ruby y ejecuta rb main.rb para cada caso; así se listará todo en la terminal.

Si lo que quieres es probar los ejemplos aquí, sin salir del post, los dejo a continuación.

Escribir archivo CSV con Ruby

 

Leer de un archivo CSV con Ruby

 


Eso es todo, aquí puedes ver más sobre Ruby.

Estoy interesado en trabajar contigo de manera remota para llevar tu idea a la realidad, formar parte de tu equipo de desarrolladores, ayudarte con tu tarea, dar asesorías y todo lo relacionado con tecnología y programación. Contáctame para más información
No te vayas sin seguirme en Twitter, Facebook y GitHub
Si tienes dudas déjalas en un comentario, pero asegúrate de seguirme antes como agradecimiento (no te cuesta nada y me ayudas mucho)


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 scripts La 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 :-)

1 Comment

Eliminar y agregar elementos a arreglo en Ruby - Parzibyte's blog · febrero 10, 2019 a las 5:00 am

[…] operador que fue usado al trabajar con CSV también se puede usar en los arreglos y funciona de manera similar a […]

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: