亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用C#將DataTable導出為Excel文件的實現(xiàn)教程

 更新時間:2025年08月08日 09:49:00   作者:CodeCraft?Studio  
在C#中將DataTable導出為Excel文件,是.NET開發(fā)中常見的任務,廣泛應用于報表生成、日志導出、系統(tǒng)間數(shù)據(jù)共享等場景,本文將介紹如何使用?Spire.XLS?for?.NET?將?DataTable?導出為?Excel(.xlsx/.xls)文件,需要的朋友可以參考下

在 C# 中將 DataTable 導出為 Excel 文件,是 .NET 開發(fā)中常見的任務,廣泛應用于報表生成、日志導出、系統(tǒng)間數(shù)據(jù)共享等場景。通過使用獨立的組件庫,開發(fā)者可以輕松將 DataTable 數(shù)據(jù)寫入 Excel 文件,并應用格式設置,生成專業(yè)、可直接使用的文檔,無需復雜配置或依賴第三方辦公軟件。

本文將介紹如何使用 Spire.XLS for .NET 將 DataTable 導出為 Excel(.xlsx/.xls)文件,包含數(shù)據(jù)創(chuàng)建、導出保存、格式設置等實用步驟。

Spire.XLS for .NET試用下載

安裝和配置 Spire.XLS

開始之前,請確保你的項目中已添加 Spire.XLS for .NET。

通過 NuGet 安裝 Spire.XLS:

CopyInstall-Package Spire.XLS

Spire.XLS 支持 .NET Framework、.NET Core、.NET 6/7+ 以及 ASP.NET 項目,且無需安裝 Microsoft Office。

分步操作:C# 將 DataTable 導出為 Excel 文件

下面的步驟將演示如何使用 Spire.XLS 將 DataTable 導出為 Excel 文件,包含數(shù)據(jù)準備、文件保存、網(wǎng)頁流導出以及格式設置等內容。

第一步:創(chuàng)建示例 DataTable

先創(chuàng)建一個包含多列的 DataTable

// 創(chuàng)建數(shù)據(jù)表
DataTable dt = new DataTable("員工信息");

// 添加列
dt.Columns.Add("員工編號", typeof(int));
dt.Columns.Add("姓名", typeof(string));
dt.Columns.Add("部門", typeof(string));
dt.Columns.Add("入職日期", typeof(DateTime));
dt.Columns.Add("工資", typeof(double));
dt.Columns.Add("是否全職", typeof(bool));
dt.Columns.Add("獎金系數(shù)", typeof(decimal));

// 添加數(shù)據(jù)行
dt.Rows.Add(1001, "張偉", "人事部", new DateTime(2021, 5, 10), 55000.5, true, 0.05m);
dt.Rows.Add(1002, "李娜", "技術部", new DateTime(2020, 11, 23), 72000.0, false, 0.03m);
dt.Rows.Add(1003, "王強", "財務部", new DateTime(2019, 8, 15), 63000.75, true, 0.07m);
dt.Rows.Add(1004, "趙敏", "市場部", new DateTime(2022, 3, 8), 48800.0, true, 0.06m);

此處為演示用示例數(shù)據(jù),實際使用中可綁定任意業(yè)務生成的 DataTable。

第二步:導入 DataTable 并保存為 Excel 文件

將 DataTable 導入到工作表中,并保存為 Excel 文件:

Workbook workbook = new Workbook();
workbook.Worksheets.Clear();
Worksheet sheet = workbook.Worksheets.Add(dt.TableName);

// 從 A1 單元格開始插入數(shù)據(jù)表
sheet.InsertDataTable(dt, true, 1, 1);

// 保存為 .xlsx 文件(推薦)
workbook.SaveToFile("員工信息.xlsx", FileFormat.Version2016);

// 保存為 .xls 文件(舊格式)
workbook.SaveToFile("員工信息.xls", FileFormat.Version97to2003);

說明:

  • Workbook 表示整個 Excel 文件。
  • InsertDataTable 方法將 DataTable 內容映射到 Excel 表格中。
  • SaveToFile 方法用于保存文件,支持多種 Excel 格式。

導出效果示意圖:

第三步:在 ASP.NET 中以流形式導出

在 Web 項目中,通常需要將 Excel 文件直接以下載流的方式返回:

MemoryStream stream = new MemoryStream();
workbook.SaveToStream(stream, FileFormat.Version2013);
stream.Position = 0;

將此 MemoryStream 返回到 ASP.NET 控制器中,即可觸發(fā)瀏覽器下載。

設置導出文件的格式與樣式

若希望導出的 Excel 文件更具可讀性和專業(yè)感,可以對內容進行格式化:

// 設置表頭樣式
CellRange header = sheet.Rows[0];
header.Style.Font.IsBold = true;
header.Style.Font.FontName = "微軟雅黑";
header.Style.Font.Size = 13;
header.Style.Color = Color.LightGray;
header.Style.Borders[BordersLineType.EdgeBottom].LineStyle = LineStyleType.Thick;

// 設置數(shù)據(jù)行樣式
for (int i =  1; i < sheet.Rows.Length; i++)
{
    CellRange dataRow = sheet.Rows[i];
    dataRow.Style.Font.FontName = "黑體";
    dataRow.Style.Font.Size = 11;
    dataRow.BorderInside();
}

// 設置日期列的顯示格式
CellRange dateColumn = sheet.Range[2, 4, sheet.Rows.Length + 1, 4];
dateColumn.Style.NumberFormat = "yyyy-mm-dd";

// 自動調整列寬
sheet.AllocatedRange.AutoFitColumns();

關鍵方法說明:

  • Style: 控制字體、顏色、邊框、數(shù)字格式等;
  • AutoFitColumns(): 自動調整列寬以適應內容;
  • NumberFormat: 格式化日期、貨幣等數(shù)據(jù)類型;
  • BorderInside(): 添加內邊框,增強表格可讀性。

格式化效果示意圖:

常見問題及解決方案

問題描述解決方法
文件無法打開或提示損壞檢查是否正確關閉流,且文件后綴與格式匹配
特殊字符或中文亂碼確保字符串為 UTF-8 編碼,字體設置支持目標語言
列寬過窄導致顯示不全使用 AutoFitColumns() 自動調整,或手動設置 ColumnWidth

總結

借助 Spire.XLS,開發(fā)者可輕松地將 C# 中的 DataTable 導出為 Excel 文件,支持 .xls 和 .xlsx 兩種格式,且無需依賴 Office 環(huán)境。無論是桌面應用還是 Web 系統(tǒng),該方法都能快速生成格式良好的 Excel 報表。

常見問答(FAQ)

Q1:如何將 DataTable 轉換為 Excel 文件?

使用 sheet.InsertDataTable() 將 DataTable 寫入工作表,然后調用 workbook.SaveToFile() 保存文件。

Q2:能否在 ASP.NET 中導出 DataTable 為 Excel?

可以,在 ASP.NET 控制器中生成工作簿,并以流的方式返回,實現(xiàn)下載功能。

Q3:.xlsx 與 .xls 有何區(qū)別?

.xlsx 是較新的格式,兼容 Excel 2007 及更高版本;.xls 為舊版格式(Excel 97-2003),行數(shù)限制為 65536 行。

以上就是使用C#將DataTable導出為Excel文件的實現(xiàn)教程的詳細內容,更多關于C# DataTable導出為Excel的資料請關注腳本之家其它相關文章!

相關文章

  • C#繪制中國國旗的方法

    C#繪制中國國旗的方法

    這篇文章主要介紹了C#繪制中國國旗的方法,以實例形式較為詳細的分析了C#圖形繪制的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-08
  • C#微信開發(fā)第一章

    C#微信開發(fā)第一章

    這篇文章主要為大家詳細介紹了C#微信開發(fā)第一章,很有參考價值和實用性,感興趣的小伙伴們可以參考一下
    2016-07-07
  • C# 中SharpMap的簡單使用實例詳解

    C# 中SharpMap的簡單使用實例詳解

    SharpMap是一個基于.net 2.0使用C#開發(fā)的Map渲染類庫,可以渲染各類GIS數(shù)據(jù)(目前支持ESRI Shape和PostGIS格式),可應用于桌面和Web程序,具體內容詳情大家參考下本文吧
    2017-08-08
  • 基于C#實現(xiàn)屏幕錄制功能

    基于C#實現(xiàn)屏幕錄制功能

    在許多應用場景中,屏幕錄制是一項非常有用的功能,不管是用于教學、演示、故障排查還是游戲錄制,本文將詳細介紹如何使用?C#?實現(xiàn)屏幕錄制功能,幫助大家快速掌握這一實用技能,需要的朋友可以參考下
    2025-03-03
  • 基于C#實現(xiàn)自定義計算的Excel數(shù)據(jù)透視表

    基于C#實現(xiàn)自定義計算的Excel數(shù)據(jù)透視表

    數(shù)據(jù)透視表(Pivot?Table)是一種數(shù)據(jù)分析工具,通常用于對大量數(shù)據(jù)進行匯總、分析和展示,本文主要介紹了C#實現(xiàn)自定義計算的Excel數(shù)據(jù)透視表的相關知識,感興趣的可以了解下
    2023-12-12
  • C# 三種方式實現(xiàn)Socket數(shù)據(jù)接收

    C# 三種方式實現(xiàn)Socket數(shù)據(jù)接收

    這篇文章主要給大家分享三種實現(xiàn)C# 實現(xiàn)Socket數(shù)據(jù)接收的方式,接下倆小編就來為大家詳細介紹吧,需要的朋友可以參考一下
    2021-10-10
  • Unity Shader實現(xiàn)動態(tài)過場切換圖片效果

    Unity Shader實現(xiàn)動態(tài)過場切換圖片效果

    這篇文章主要為大家詳細介紹了Unity Shader實現(xiàn)動態(tài)過場切換圖片效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • AOP從靜態(tài)代理到動態(tài)代理(Emit實現(xiàn))詳解

    AOP從靜態(tài)代理到動態(tài)代理(Emit實現(xiàn))詳解

    AOP為Aspect Oriented Programming的縮寫,意思是面向切面編程的技術。下面這篇文章主要給大家介紹了關于AOP從靜態(tài)代理到動態(tài)代理(Emit實現(xiàn))的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2018-09-09
  • C#中的圖像Image類與打印Printing類用法

    C#中的圖像Image類與打印Printing類用法

    這篇文章介紹了C#中圖像Image類與打印Printing類的用法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • C#使用控制臺列出當前所有可用的打印機列表

    C#使用控制臺列出當前所有可用的打印機列表

    這篇文章主要介紹了C#使用控制臺列出當前所有可用的打印機列表,涉及C#操作計算機硬件的相關使用技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04

最新評論