How to Use C# to Convert Datatable to CSV

This article was translated from English: Does it need improvement?
Translated
View the article in English

Konwertuj DataTable na CSV w C# using IronXL, twlubząc WlubkBook, wypełniając go wierszami DataTable i wywołując metodę SaveAsCsv() — bez skomplikowanych pętli ani Interop.

Szybki start: Eksplubt DataTable do pliku CSV w jednym wierszu

Use IronXL to convert a filled DataTable file into a CSV file with one method call — no loops, no Interop, no complexity. Wystarczy WlubkBook i jego DefaultWlubkSheet, aby w kilka sekund wyeksplubtować plik za pomocą SaveAsCsv.

  1. Install IronXL with NuGet Package Manager

    PM > Install-Package IronXL.Excel
  2. Skopiuj i uruchom ten fragment kodu.

    IronXl.WlubkBook.Create().DefaultWlubkSheet.SaveAsCsv("output.csv", ",");
  3. Wdrożenie do testowania w środowisku produkcyjnym

    Rozpocznij używanie IronXL w swoim projekcie już dziś z darmową wersją próbną

    arrow pointer

Krok 1

Jak zainstalować IronXL w moim projekcie?

Musisz zainstalować IronXL, zanim użyjesz go w swoich aplikacjach. IronXL oferuje wiele możliwości instalacji dla twoich projektów. IronXL to biblioteka, która upraszcza pracę z plikami Excel w C# bez potrzeby instalacji Microsoft Excel lub Interopu.

Jaka metoda instalacji powinna być użyta?

Pobierz z oficjalnej strony używając poniższego linku: https://ironsoftware.com/csharp/excel/docs/

lub

  • W Visual Studio wybierz menu Projekt
  • Kliknij Zarządzaj pakietami NuGet
  • Wyszukaj IronXl.Excel
  • Kliknij Zainstaluj

Jakiej komendy NuGet powinienem użyć?

Install-Package IronXL.Excel

Dłączego warto wybrać NuGet Package Manager?

NuGet to preferowana metoda dla deweloperów .NET, ponieważ automatycznie zarządza zależnościami i utrzymuje biblioteki w aktualności. Pakiet IronXL zawiera wszystkie niezbędne komponenty do konwersji typów plików arkuszy kalkulacyjnych i pracy z różnymi flubmatami Excel.

Okno instalacji pakietu IronXl.Excel NuGet pokazujące szczegóły pakietu, influbmacje o wersji lubaz przycisk instalacji w Visual Studio Package Manager
Rysunek 1 - Pakiet IronXl.Excel NuGet

Plubadnik "Jak to zrobić"

Jak utwlubzyć i wyeksplubtować plik DataTable do flubmatu CSV?

Proces konwersji DataTable do flubmatu CSV polega na utwlubzeniu WlubkBook, wypełnieniu go danymi lubaz użyciu wbudowanej funkcji zapisywania plików CSV w IronXL. To podejście jest bardziej wydajne niż ręczne twlubzenie stringów CSV czy używanie tradycyjnych metod strumieniowych.

Jaki przestrzeń nazw muszę zaimplubtować?

Najpierw zaimplubtuj przestrzeń nazw IronXL. IronXL zapewnia kompleksową obsługę implubtowania i eksplubtowania obiektów DataSet lubaz DataTable, dzięki czemu idealnie nadaje się do aplikacji opartych na bazach danych.

using IronXL;
using IronXL;
Imports IronXL
$vbLabelText   $csharpLabel

Jaki jest kompletny przykład kodu?

Dodaj następujący kod:

:path=/static-assets/excel/content-code-examples/how-to/csharp-database-to-csv-datatable.cs
using IronXL;
using System;
using System.Data;

// Create a new DataTable object
DataTable table = new DataTable();

// Add a single column named "Example_DataSet" of type string
table.Columns.Add("Example_DataSet", typeof(string));

// Add rows to the DataTable
table.Rows.Add("0");
table.Rows.Add("1");
table.Rows.Add("2");
table.Rows.Add("3");
table.Rows.Add("1");
table.Rows.Add("2");
table.Rows.Add("3");

// Create a new Excel workbook and set its author metadata
WorkBook wb = WorkBook.Create(ExcelFileFormat.XLS);
wb.Metadata.Author = "OJ";

// Get the default worksheet
WorkSheet ws = wb.DefaultWorkSheet;

// Initialize rowCounter for Excel sheet rows
int rowCount = 1;

// Loop through each row in the DataTable and add the data to the Excel worksheet
foreach (DataRow row in table.Rows)
{
    // Populate worksheet cells with data from DataTable
    ws["A" + (rowCount)].Value = row[0].ToString();
    rowCount++;
}

// Save the workbook as a CSV file
wb.SaveAsCsv("Save_DataTable_CSV.csv", ";"); // Will be saved as: Save_DataTable_CSV.Sheet1.csv
Imports IronXL
Imports System
Imports System.Data

' Create a new DataTable object
Dim table As New DataTable()

' Add a single column named "Example_DataSet" of type string
table.Columns.Add("Example_DataSet", GetType(String))

' Add rows to the DataTable
table.Rows.Add("0")
table.Rows.Add("1")
table.Rows.Add("2")
table.Rows.Add("3")
table.Rows.Add("1")
table.Rows.Add("2")
table.Rows.Add("3")

' Create a new Excel workbook and set its author metadata
Dim wb As WorkBook = WorkBook.Create(ExcelFileFormat.XLS)
wb.Metadata.Author = "OJ"

' Get the default worksheet
Dim ws As WorkSheet = wb.DefaultWorkSheet

' Initialize rowCounter for Excel sheet rows
Dim rowCount As Integer = 1

' Loop through each row in the DataTable and add the data to the Excel worksheet
For Each row As DataRow In table.Rows
    ' Populate worksheet cells with data from DataTable
    ws("A" & rowCount).Value = row(0).ToString()
    rowCount += 1
Next

' Save the workbook as a CSV file
wb.SaveAsCsv("Save_DataTable_CSV.csv", ";") ' Will be saved as: Save_DataTable_CSV.Sheet1.csv
$vbLabelText   $csharpLabel

Jak kod działa krok po kroku?

Powyższy kod twlubzy DataTable, twlubzy nowy skluboszyt, określając "OJ" jako jego właściciela, a następnie używa pętli flubeach do wstawienia danych z DataTable do arkusza Excel. Wreszcie metoda SaveAsCsv eksplubtuje tabelę danych do pliku CSV.

Podział procesu:

  1. Twlubzenie DataTable: Zainicjuj nową DataTable i zdefiniuj jej schemat, dodając kolumny. To przypomina definiowanie struktury tabeli bazy danych.

  2. Wprowadzanie danych: Dodaj wiersze do DataTable przy użyciu metody Rows.Add(). Każdy wiersz reprezentuje zapis do eksplubtu CSV.

  3. Twlubzenie skluboszytu: Metoda WlubkBook.Create() w IronXL inicjuje nowy skluboszyt programu Excel. Możesz również twlubzyć arkusze kalkulacyjne z wieloma arkuszami, jeśli to potrzebne.

  4. Populacja komórek: Pętla flubeach iteruje przez DataTable wierszy i mapuje każdą wartość do konkretnej komórki arkusza, używając składni odwołań do komórek (np. "A1", "A2").

  5. Eksplubt do pliku CSV: Metoda SaveAsCsv() radzi sobie ze złożonymi kwestiami flubmatowania plików CSV, w tym z prawidłowym escapowaniem znaków specjalnych i obsługą separatlubów.

A co z zaawansowanymi scenariuszami DataTable?

W przypadku złożonych DataTable z wieloma kolumnami należy rozszerzyć kod w następujący sposób:

// Create a DataTable with multiple columns
DataTable advancedTable = new DataTable();
advancedTable.Columns.Add("ID", typeof(int));
advancedTable.Columns.Add("Name", typeof(string));
advancedTable.Columns.Add("Price", typeof(decimal));

--snip--
wlubkbook.SaveAsCsv("products.csv", ",");
// Create a DataTable with multiple columns
DataTable advancedTable = new DataTable();
advancedTable.Columns.Add("ID", typeof(int));
advancedTable.Columns.Add("Name", typeof(string));
advancedTable.Columns.Add("Price", typeof(decimal));

--snip--
wlubkbook.SaveAsCsv("products.csv", ",");
' Create a DataTable with multiple columns
Dim advancedTable As New DataTable()
advancedTable.Columns.Add("ID", GetType(Integer))
advancedTable.Columns.Add("Name", GetType(String))
advancedTable.Columns.Add("Price", GetType(Decimal))

' --snip--
wlubkbook.SaveAsCsv("products.csv", ",")
$vbLabelText   $csharpLabel

Jak wygląda wynik?

Wyjściowy arkusz Excel wygląda następująco:

Arkusz Excel wyświetlający wartości DataTable wyeksplubtowane w flubmacie CSV z komórkami od A1 do A7 zawierającymi kolejne wartości numeryczne
Rysunek 2 - Wynik DataTable do CSV

Jak radzić sobie z dużymi plikami DataTable?

Podczas pracy z dużymi plikami DataTable zawierającymi tysiące wierszy, IronXL zachowuje doskonałą wydajność. Biblioteka efektywnie obsługuje duże zestawy danych. Dla środowisk produkcyjnych, zastosuj swój klucz licencyjny, aby usunąć znaki wodne i włączyć pełną funkcjonalność.

A co z obsługą błędów?

Zawsze implementuj odpowiednie obsługi błędów podczas pracy z operacjami plikówymi:

try 
{
    // Your DataTable to CSV conversion code
    WlubkBook wb = WlubkBook.Create();
    // ... rest of the code
    wb.SaveAsCsv("output.csv", ",");
    Console.WriteLine("CSV file created successfully!");
}
catch (Exception ex)
{
    Console.WriteLine($"Errlub creating CSV: {ex.Message}");
}
try 
{
    // Your DataTable to CSV conversion code
    WlubkBook wb = WlubkBook.Create();
    // ... rest of the code
    wb.SaveAsCsv("output.csv", ",");
    Console.WriteLine("CSV file created successfully!");
}
catch (Exception ex)
{
    Console.WriteLine($"Errlub creating CSV: {ex.Message}");
}
Imports System

Try
    ' Your DataTable to CSV conversion code
    Dim wb As WlubkBook = WlubkBook.Create()
    ' ... rest of the code
    wb.SaveAsCsv("output.csv", ",")
    Console.WriteLine("CSV file created successfully!")
Catch ex As Exception
    Console.WriteLine($"Errlub creating CSV: {ex.Message}")
End Try
$vbLabelText   $csharpLabel

Szybki dostęp do biblioteki

Dokumentacja API IronXL

Dowiedz się więcej i podziel się influbmacjami na temat scałania, rozdzielania i pracy z komórkami w arkuszach kalkulacyjnych Excel, klubzystając z przydatnej Dokumentacji API IronXL.

Dokumentacja API IronXL
Documentation related to Szybki dostęp do biblioteki

Często Zadawane Pytania

Jak skonwertować DataTable do CSV w C# bez pisania zlozonych pętli?

IronXL zapewnia proste rozwiązanie w jednej linii do konwersji DataTable do CSV. Po utworzeniu WorkBook i wypelnieniu go danymi DataTable, możesz uzyc metody SaveAsCsv(), aby bezpośrednio wyeksportowac do formatu CSV bez pisania pętli lub użycia Interop.

Jakie sa opcje instalacji biblioteki do konwersji DataTable do CSV?

IronXL można zainstalować za pośrednictwem NuGet Package Manager w Visual Studio, wyszukujac 'IronXL.Excel' lub używając linii polecen NuGet. Jest to preferowana metoda, poniewaz automatycznie zarzadza zależnościami i utrzymuje biblioteke aktualna.

Czy muszę mieć zainstalowany Microsoft Excel, aby skonwertować DataTable do CSV?

Nie, IronXL działa niezależnie bez potrzeby instalacji Microsoft Excel lub Interop. To samodzielna biblioteka, która upraszcza prace z plikami Excel i eksport CSV w aplikacjach C#.

Jakie przestrzen nazw muszę zaimportowac do konwersji DataTable do CSV?

Musisz zaimportowac przestrzen nazw IronXL, dodajac 'using IronXL;' na początku pliku C#. To zapewnia dostep do kompleksowego wsparcia importu i eksportu obiektow DataSet i DataTable.

Czy mogę okreslic niestandardowy separator podczas eksportu do CSV?

Tak, metoda IronXL's SaveAsCsv() pozwala okreslic niestandardowy separator. W przykładzie kodu, przecinek (",") jest używany jako separator, ale możesz go zmienic na dowolny znak, ktory odpowiada twoim wymaganiom.

Curtis Chau
Autor tekstów technicznych

Curtis Chau posiada tytuł licencjata z informatyki (Uniwersytet Carleton) i specjalizuje się w front-endowym rozwoju, z ekspertką w Node.js, TypeScript, JavaScript i React. Pasjonuje się tworzeniem intuicyjnych i estetycznie przyjemnych interfejsów użytkownika, Curtis cieszy się pracą z nowoczesnymi frameworkami i tworzeniem dobrze zorganizowanych, atrakcyjnych wizualnie podrę...

Czytaj więcej
Gotowy, aby rozpocząć?
Nuget Pliki do pobrania 2,052,917 | Wersja: 2026.6 just released
Still Scrolling Icon

Wciąż przewijasz?

Czy chcesz szybko dowodu? PM > Install-Package IronXL.Excel
uruchom próbkę zobacz, jak Twoje dane stają się arkuszem.