Conversor CSV Aprende programación con ejercicios C# Sharp

Lección:

Administración de Archivos


Ejercicio:

Conversor CSV 35


Objetivo:

El CSV ("Valores separados por comas") es un formato de intercambio utilizado por muchas hojas de cálculo y bases de datos de sistemas de gestión. Es una serie de valores separados por comas encerrados entre comillas, aunque hay variantes que no usan comillas, o que usan punto y coma como separador. A menudo las cifras no están entre comillas. Un archivo de ejemplo sería:

"Juan", "López Pérez", "Alicante", 25
"Antonio", "Pérez López", "Madrid", 27

Debe crear un programa que lea un archivo CSV como el anterior, con cuatro bloques de datos (los primeros 3 son de texto y el último será numérico), cada uno de los cuales está en una línea, y generar un archivo de texto cada entrada contiene una línea como esta:

John
Pérez López
Alicantino
25
Anthony
Pérez López
Madrid
27


Código:

using System;
using System.IO;
namespace ReaderCSV
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("CSV READER");
            Console.WriteLine("--------------------------------------");
            Console.Write("Enter name of file .csv: ");

            string nameFile = Console.ReadLine();
            StreamReader myfile;
            string cadena;
            int position;

            try
            {
                myfile = new StreamReader(nameFile, System.Text.Encoding.Default);
                string line;
                do
                {
                    line = myfile.ReadLine();
                    if ((line != null) && (line != ""))
                    {
                        try
                        {
                            line = line.Replace("\"", "");

                            position = line.IndexOf(';');
                            cadena = line.Substring(0, position);
                            line = line.Remove(0, position + 1);
                            Console.WriteLine(cadena + "\n");

                            position = line.IndexOf(';');
                            cadena = line.Substring(0, position);
                            line = line.Remove(0, position + 1);
                            Console.WriteLine(cadena + "\n");

                            position = line.IndexOf(';');
                            cadena = line.Substring(0, position);
                            line = line.Remove(0, position + 1);
                            Console.WriteLine(cadena + "\n");

                            cadena = line.Substring(0);
                            Console.WriteLine(cadena + "\n");
                        }
                        catch (Exception e)
                        {
                            Console.WriteLine("Error !!! " + e.Message);
                        }
                    }
                }
                while (line != null);
            }
            catch (Exception e)
            {
                Console.WriteLine("Error !!!" + e.Message);
            }
        }
    }
}