您好,登錄后才能下訂單哦!
本文小編為大家詳細(xì)介紹“C#怎么把DataTable導(dǎo)出為Excel文件”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“C#怎么把DataTable導(dǎo)出為Excel文件”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識(shí)吧。
實(shí)現(xiàn)DataTable轉(zhuǎn)為Excel文件,和上次分享的Excel文件轉(zhuǎn)為DataTable互為反操作。DataTable轉(zhuǎn)化為Excel文件是通過傳入一個(gè)DataTable類型的參數(shù),然后將傳入的DataTable轉(zhuǎn)化為Excel文件。實(shí)現(xiàn)關(guān)鍵代碼如下:
方法一:
/// <summary> /// DataTable數(shù)據(jù)導(dǎo)出Excel /// </summary> /// <param name="data"></param> /// <param name="filepath"></param> public static void DataTableExport(DataTable data, string filepath) { try { //Workbook book = new Workbook("E:\\test.xlsx"); //打開工作簿 Workbook book = new Workbook(); //創(chuàng)建工作簿 Worksheet sheet = book.Worksheets[0]; //創(chuàng)建工作表 Cells cells = sheet.Cells; //單元格 //創(chuàng)建樣式 Aspose.Cells.Style style = book.Styles[book.Styles.Add()]; style.Borders[Aspose.Cells.BorderType.LeftBorder].LineStyle = Aspose.Cells.CellBorderType.Thin; //應(yīng)用邊界線 左邊界線 style.Borders[Aspose.Cells.BorderType.RightBorder].LineStyle = Aspose.Cells.CellBorderType.Thin; //應(yīng)用邊界線 右邊界線 style.Borders[Aspose.Cells.BorderType.TopBorder].LineStyle = Aspose.Cells.CellBorderType.Thin; //應(yīng)用邊界線 上邊界線 style.Borders[Aspose.Cells.BorderType.BottomBorder].LineStyle = Aspose.Cells.CellBorderType.Thin; //應(yīng)用邊界線 下邊界線 style.HorizontalAlignment = TextAlignmentType.Center; //單元格內(nèi)容的水平對齊方式文字居中 style.Font.Name = "宋體"; //字體 style1.Font.IsBold = true; //設(shè)置粗體 style.Font.Size = 11; //設(shè)置字體大小 //style.ForegroundColor = System.Drawing.Color.FromArgb(153, 204, 0); //背景色 //style.Pattern = Aspose.Cells.BackgroundType.Solid; //背景樣式 //style.IsTextWrapped = true; //單元格內(nèi)容自動(dòng)換行 //表格填充數(shù)據(jù) int Colnum = data.Columns.Count;//表格列數(shù) int Rownum = data.Rows.Count;//表格行數(shù) //生成行 列名行 for (int i = 0; i < Colnum; i++) { cells[0, i].PutValue(data.Columns[i].ColumnName); //添加表頭 cells[0, i].SetStyle(style); //添加樣式 //cells.SetColumnWidth(i, data.Columns[i].ColumnName.Length * 2 + 1.5); //自定義列寬 //cells.SetRowHeight(0, 30); //自定義高 } //生成數(shù)據(jù)行 for (int i = 0; i < Rownum; i++) { for (int k = 0; k < Colnum; k++) { cells[1 + i, k].PutValue(data.Rows[i][k].ToString()); //添加數(shù)據(jù) cells[1 + i, k].SetStyle(style); //添加樣式 } cells[1 + i, 5].Formula = "=B" + (2 + i) + "+C" + (2 + i);//給單元格設(shè)置計(jì)算公式,計(jì)算班級(jí)總?cè)藬?shù) } sheet.AutoFitColumns(); //自適應(yīng)寬 book.Save(filepath); //保存 GC.Collect(); } catch (Exception e) { logger.Error("生成excel出錯(cuò):" + e.Message); } }
方法二:
public void ToExcel(DataTable dt) { #region 3s var FilePath = @"D:\ToExcel\";//產(chǎn)生Excel文件路徑 DeleteFile(FilePath); //創(chuàng)建全新的Workbook var workbook = new HSSFWorkbook();//一個(gè)sheet最多65536行 var count = 0; for (double i = 0; i < Convert.ToDouble(dt.Rows.Count) / Convert.ToDouble(65534); i++)//每個(gè)Excel文件的一個(gè)頁簽只能存放65536行數(shù)據(jù) { var row_index = 0; //創(chuàng)建Sheet workbook.CreateSheet("Sheet" + i); //根據(jù)Sheet名字獲得Sheet對象 var sheet = workbook.GetSheet("Sheet" + i); IRow row; row = sheet.CreateRow(row_index); //寫入標(biāo)題 for (int j = 0; j < dt.Columns.Count; j++) { row.CreateCell(j).SetCellValue(dt.Columns[j].Caption.ToString()); } row = sheet.CreateRow(++row_index); //寫入數(shù)據(jù) for (int j = 0; j < (dt.Rows.Count - count > 65534 ? 65534 : dt.Rows.Count - count); j++) { var r = dt.Rows[j + count]; for (int k = 0; k <dt.Columns.Count; k++) { row.CreateCell(k).SetCellValue(r[k].ToString()); //如果是數(shù)字,判斷是否需要轉(zhuǎn)換為數(shù)字 //if (IsNumeric(r[k].ToString())) //{ // row.CreateCell(k).SetCellValue(Convert.ToDouble(r[k].ToString())); //} //else //{ // row.CreateCell(k).SetCellValue(r[k].ToString()); //} } row = sheet.CreateRow(++row_index); } count += row_index - 2; } //保存Workbook方式一: 以文件形式保存到服務(wù)器中(每次導(dǎo)出都會(huì)生成一個(gè)文件,慎重使用) var FileName = DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls"; var sw = File.Create(FilePath + FileName); workbook.Write(sw); sw.Close(); var EC = new ExcelConverter(); EC.WebopenExcel(Response, FilePath + FileName); #endregion }
讀到這里,這篇“C#怎么把DataTable導(dǎo)出為Excel文件”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。