Scrivere dati in C# in un file CSV
-
Programma C# per scrivere dati in un file
CSV
utilizzando i metodi di classeCsvHelper
-
Programma C# per scrivere dati in un file
CSV
utilizzando il metodoWriteAllText()

I file CSV
sono di grande utilità per memorizzare i dati in modo organizzato. Puoi scrivere e leggere dati da e verso un file CSV
utilizzando diversi linguaggi di programmazione.
In C# abbiamo diversi metodi per leggere un file CSV
e scrivere i dati in un file CSV
. Questo articolo si concentra sui diversi metodi per scrivere dati in un file CSV
.
Programma C# per scrivere dati in un file CSV
utilizzando i metodi di classe CsvHelper
In C#, abbiamo una libreria chiamata CsvHelper
per leggere e scrivere file CSV
. Questa libreria non è fornita per impostazione predefinita. Piuttosto, dobbiamo scaricarlo. Fornisce metodi come GetRecords
e WriteRecords
per leggere e scrivere un file CSV
. Questa è una libreria efficiente per leggere e scrivere facilmente file CSV
.
Il seguente codice di esempio mostra un programma che crea un file CSV
e vi scrive i dati.
Codice di esempio:
using System;
using System.IO;
using System.Text;
using CsvHelper;
namespace CsvExample
{
public class Project
{
public string PersonName { get; set; }
public string Title { get; set; }
}
public class Program
{
static void Main(string[] args)
{
var data = new[]
{
new Project { CustomerName = "Olivia", Title = "Mother"},
new Project { CustomerName = "Lili", Title = "Elder Sister"}
};
using (var mem = new MemoryStream())
using (var writer = new StreamWriter(mem))
using (var csvWriter = new CsvWriter(writer))
{
csvWriter.Configuration.Delimiter = ";";
csvWriter.Configuration.HasHeaderRecord = true;
csvWriter.Configuration.AutoMap<Project>();
csvWriter.WriteHeader<Project>();
csvWriter.WriteRecords(data);
writer.Flush();
var result = Encoding.UTF8.GetString(mem.ToArray());
Console.WriteLine(result);
}
}
}
}
Produzione:
PersonName;Title
Olivia;Mother
Lili;Elder Sister
Programma C# per scrivere dati in un file CSV
utilizzando il metodo WriteAllText()
Il metodo WriteAllText()
crea un file, scrive i dati nel file e quindi chiude il file. Se il file esiste già, sovrascrive i dati nel file.
La sintassi corretta per utilizzare questo metodo è la seguente:
WriteAllText (StringPath, StringContents);
Codice di esempio:
using System;
using System.IO;
using System.Text;
namespace CsvExample
{
public class Program
{
static void Main(string[] args)
{
string strFilePath = @"D:\New folder\Data.csv";
string strSeperator = ",";
StringBuilder sbOutput = new StringBuilder();
int[][] inaOutput = new int[][]{
new int[]{1000, 2000, 3000, 4000, 5000},
new int[]{6000, 7000, 8000, 9000, 10000},
new int[]{11000, 12000, 13000, 14000, 15000}
};
int ilength = inaOutput.GetLength(0);
for (int i = 0; i &lt; ilength; i++)
sbOutput.AppendLine(string.Join(strSeperator, inaOutput[i]));
// Create and write the csv file
File.WriteAllText(strFilePath, sbOutput.ToString());
// To append more lines to the csv file
File.AppendAllText(strFilePath, sbOutput.ToString());
}
}
}
Produzione:
//CSV file created in the given directory
Fornisce diverse eccezioni come ArgumentException
, ArgumentNullException
, PathTooLongException
, DirectoryNotFoundException
, IOException
e UnauthorizedAccessException
. Queste eccezioni potrebbero essere gestite utilizzando un blocco try-catch
.