[C#] Export dataset to multi work sheet Excel in Csharp
Hi! xin chào các bạn. Hôm nay, mình sẽ hướng dẫn các bạn export dữ liệu từ dataset ra một file excel bao gồm nhiều work sheet bằng C# . Mình ví dụ: Nếu các bạn có một database gồm nhiều table, bây giờ các bạn muốn xuất các table trong ...
Hi! xin chào các bạn. Hôm nay, mình sẽ hướng dẫn các bạn export dữ liệu từ dataset ra một file excel bao gồm nhiều work sheet bằng C#.
Mình ví dụ:
Nếu các bạn có một database gồm nhiều table, bây giờ các bạn muốn xuất các table trong database đó ra file dữ liệu Excel. Mỗi một table là một Sheet.
Mình chia sẽ các bạn sử dụng thư viện Close XML để làm việc đó một cách đơn giản.
Giao diện demo ứng dụng:
Đầu tiên, các bạn cần cài đặt thư viện Close XML từ Nuget vào project của mình.
Các từ giao diện dòng lệnh cài đặt Nuget các bạn gõ lệnh sau:
PM> Install-Package ClosedXML
Lưu ý: các bạn phải chạy Net Framework 4.5.2
Theo ví dụ của mình:
Sẽ xuất dữ liệu ra file excel gồm 3 bảng: Customers, Employee, Catagories.
Mình sử dụng database mẫu Nowthwind, các bạn có thể download database mẫu từ google nhé.
Source code C#:
using System; using System.Windows.Forms; using System.IO; using System.Data; using System.Reflection; using ClosedXML.Excel; using System.Data.SqlClient; namespace Export_DataTable_Excel { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { DataSet ds = new DataSet(); string constr = "Data Source=.;Initial Catalog=NORTHWND;Integrated Security=True"; string query = "SELECT TOP 10 CustomerId,ContactName,City,Country FROM Customers GO SELECT TOP 5 EmployeeID,(FirstName + + LastName) EmployeeName,City,Country FROM Employees GO SELECT CategoryName, Description FROM dbo.Categories"; using (SqlConnection con = new SqlConnection(constr)) { using (SqlCommand cmd = new SqlCommand(query)) { using (SqlDataAdapter sda = new SqlDataAdapter()) { cmd.Connection = con; sda.SelectCommand = cmd; sda.Fill(ds); ds.Tables[0].TableName = "Customers"; ds.Tables[1].TableName = "Employees"; ds.Tables[2].TableName = "Categories"; } } } XLWorkbook wb = new XLWorkbook(); for (int i = 0; i < ds.Tables.Count; i++) { wb.Worksheets.Add(ds.Tables[i], ds.Tables[i].TableName); } string filePath = ""; if (folderBrowserDialog1.ShowDialog() == System.Windows.Forms.DialogResult.OK) { filePath = folderBrowserDialog1.SelectedPath; } wb.SaveAs(filePath + "DataGridViewExport.xlsx"); } } }
HAVE FUN :)
DOWNLOAD SOURCE