翻譯|使用教程|編輯:吉煒煒|2025-08-07 10:25:43.610|閱讀 117 次
概述:在 C# 中將 DataTable 導(dǎo)出為 Excel 文件,是 .NET 開發(fā)中常見的任務(wù),廣泛應(yīng)用于報(bào)表生成、日志導(dǎo)出、系統(tǒng)間數(shù)據(jù)共享等場景。本文將介紹如何使用 Spire.XLS for .NET 將 DataTable 導(dǎo)出為 Excel(.xlsx/.xls)文件,包含數(shù)據(jù)創(chuàng)建、導(dǎo)出保存、格式設(shè)置等實(shí)用步驟。
# 界面/圖表報(bào)表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關(guān)鏈接:
在 C# 中將 DataTable 導(dǎo)出為 Excel 文件,是 .NET 開發(fā)中常見的任務(wù),廣泛應(yīng)用于報(bào)表生成、日志導(dǎo)出、系統(tǒng)間數(shù)據(jù)共享等場景。通過使用獨(dú)立的組件庫,開發(fā)者可以輕松將 DataTable 數(shù)據(jù)寫入 Excel 文件,并應(yīng)用格式設(shè)置,生成專業(yè)、可直接使用的文檔,無需復(fù)雜配置或依賴第三方辦公軟件。
本文將介紹如何使用 Spire.XLS for .NET 將 DataTable 導(dǎo)出為 Excel(.xlsx/.xls)文件,包含數(shù)據(jù)創(chuàng)建、導(dǎo)出保存、格式設(shè)置等實(shí)用步驟。
歡迎加入Spire技術(shù)交流Q群(125237868),與更多小伙伴一起提升文檔開發(fā)技能~
開始之前,請確保你的項(xiàng)目中已添加 Spire.XLS for .NET。
通過 NuGet 安裝 Spire.XLS:
CopyInstall-Package Spire.XLS
Spire.XLS 支持 .NET Framework、.NET Core、.NET 6/7+ 以及 ASP.NET 項(xiàng)目,且無需安裝 Microsoft Office。
下面的步驟將演示如何使用 Spire.XLS 將 DataTable 導(dǎo)出為 Excel 文件,包含數(shù)據(jù)準(zhǔn)備、文件保存、網(wǎng)頁流導(dǎo)出以及格式設(shè)置等內(nèi)容。
先創(chuàng)建一個(gè)包含多列的 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("獎(jiǎng)金系數(shù)", typeof(decimal)); // 添加數(shù)據(jù)行 dt.Rows.Add(1001, "張偉", "人事部", new DateTime(2021, 5, 10), 55000.5, true, 0.05m); dt.Rows.Add(1002, "李娜", "技術(shù)部", new DateTime(2020, 11, 23), 72000.0, false, 0.03m); dt.Rows.Add(1003, "王強(qiáng)", "財(cái)務(wù)部", 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ù),實(shí)際使用中可綁定任意業(yè)務(wù)生成的 DataTable。
將 DataTable 導(dǎo)入到工作表中,并保存為 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);
說明:
導(dǎo)出效果示意圖:
在 Web 項(xiàng)目中,通常需要將 Excel 文件直接以下載流的方式返回:
MemoryStream stream = new MemoryStream(); workbook.SaveToStream(stream, FileFormat.Version2013); stream.Position = 0;將此 MemoryStream 返回到 ASP.NET 控制器中,即可觸發(fā)瀏覽器下載。
若希望導(dǎo)出的 Excel 文件更具可讀性和專業(yè)感,可以對內(nèi)容進(jìn)行格式化:
// 設(shè)置表頭樣式 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è)置數(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(); } // 設(shè)置日期列的顯示格式 CellRange dateColumn = sheet.Range[2, 4, sheet.Rows.Length + 1, 4]; dateColumn.Style.NumberFormat = "yyyy-mm-dd"; // 自動調(diào)整列寬 sheet.AllocatedRange.AutoFitColumns();
關(guān)鍵方法說明:
格式化效果示意圖:
問題描述 | 解決方法 |
---|---|
文件無法打開或提示損壞 | 檢查是否正確關(guān)閉流,且文件后綴與格式匹配 |
特殊字符或中文亂碼 | 確保字符串為 UTF-8 編碼,字體設(shè)置支持目標(biāo)語言 |
列寬過窄導(dǎo)致顯示不全 | 使用 AutoFitColumns() 自動調(diào)整,或手動設(shè)置 ColumnWidth |
借助 Spire.XLS,開發(fā)者可輕松地將 C# 中的 DataTable 導(dǎo)出為 Excel 文件,支持 .xls 和 .xlsx 兩種格式,且無需依賴 Office 環(huán)境。無論是桌面應(yīng)用還是 Web 系統(tǒng),該方法都能快速生成格式良好的 Excel 報(bào)表。
使用 sheet.InsertDataTable() 將 DataTable 寫入工作表,然后調(diào)用 workbook.SaveToFile() 保存文件。
可以,在 ASP.NET 控制器中生成工作簿,并以流的方式返回,實(shí)現(xiàn)下載功能。
.xlsx 是較新的格式,兼容 Excel 2007 及更高版本;.xls 為舊版格式(Excel 97-2003),行數(shù)限制為 65536 行。
歡迎下載|體驗(yàn)更多E-iceblue產(chǎn)品
獲取更多信息請咨詢 ;技術(shù)交流Q群(125237868)
————————————————————————————————————————
關(guān)于慧都科技:
慧都科技是一家行業(yè)數(shù)字化解決方案公司,長期專注于軟件、油氣與制造行業(yè)。公司基于深入的業(yè)務(wù)理解與管理洞察,以系統(tǒng)化的業(yè)務(wù)建模驅(qū)動技術(shù)落地,幫助企業(yè)實(shí)現(xiàn)智能化運(yùn)營與長期競爭優(yōu)勢。在軟件工程領(lǐng)域,我們提供開發(fā)控件、研發(fā)管理、代碼開發(fā)、部署運(yùn)維等軟件開發(fā)全鏈路所需的產(chǎn)品,提供正版授權(quán)采購、技術(shù)選型、個(gè)性化維保等服務(wù),幫助客戶實(shí)現(xiàn)技術(shù)合規(guī)、降本增效與風(fēng)險(xiǎn)可控。慧都科技E-iceblue的官方授權(quán)代理商,提供E-iceblue系列產(chǎn)品免費(fèi)試用,咨詢,正版銷售等于一體的專業(yè)化服務(wù)。E-iceblue旗下Spire系列產(chǎn)品是國產(chǎn)文檔處理領(lǐng)域的優(yōu)秀產(chǎn)品,支持國產(chǎn)化,幫助企業(yè)高效構(gòu)建文檔處理的應(yīng)用程序。
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉(zhuǎn)載自:慧都網(wǎng)