麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > C# > 正文

C#如何將DataTable導出到Excel解決方案

2020-01-24 03:38:45
字體:
來源:轉載
供稿:網友
最近,由于公司項目中需要將系統內用戶操作的所有日志進行轉存備份,考慮到以后可能還需要還原,所以最后決定將日志數據備份到Excel中。

下面是我項目當中Excel.cs這個類的全部代碼,通過這個類可以很容易地將DataTable中的數據導入到Excel方法中。

首先,必須要下載NPOI.dll這個程序集,
類代碼如下:
復制代碼 代碼如下:

using System;
using NPOI.HSSF;
using NPOI.HPSF;
using NPOI.HSSF.UserModel;
using NPOI.HSSF.Util;
using NPOI.SS.UserModel;
using System.Collections;
using System.IO;
using System.Data;
namespace BackupAttach
{
public class Excel
{
private HSSFWorkbook _workBook;
private ISheet _wbSheet = null;
private DataColumnCollection _columns = null;
private int _col = 0; //total columns
private int _row = 0; //total rows
private int _sheet = 0; //total sheets
private int _sheetRowNum = 65536; //each sheet allow rows
public Excel()
{
InstanceWorkBook();
}
/// <summary>
/// 實例方法
/// </summary>
/// <param name="sheetRowNum">單個表單允許的最大行數</param>
public Excel(int sheetRowNum)
{
_sheetRowNum = sheetRowNum;
InstanceWorkBook();
}
/// <summary>
/// 實例方法
/// </summary>
/// <param name="columns">表頭</param>
public Excel(DataColumnCollection columns)
{
_columns = columns;
InstanceWorkBook();
}
private void InstanceWorkBook()
{
/////cretate WorkBook
_workBook = new HSSFWorkbook();
var dsi = PropertySetFactory.CreateDocumentSummaryInformation();
dsi.Company = "BaiyiTimes";
_workBook.DocumentSummaryInformation = dsi;
////create a entry of SummaryInformation
var si = PropertySetFactory.CreateSummaryInformation();
si.Subject = "Etimes Secure Document System Log Backup";
_workBook.SummaryInformation = si;
}
private DataColumnCollection GetColumns(DataColumnCollection columns)
{
return columns == null || columns.Count == 0 ? _columns : columns;
}
private ISheet GetSheet(ISheet sheet)
{
return sheet == null ? _wbSheet : sheet;
}
private void CreateHeader(ISheet sheet, DataColumnCollection columns)
{
_columns = GetColumns(columns);
/////create row of column
var oRow = sheet.CreateRow(0);
foreach (DataColumn column in _columns)
{
var oCell = oRow.CreateCell(_col);
var style1 = _workBook.CreateCellStyle();
style1.FillForegroundColor = HSSFColor.BLUE.index2;
style1.FillPattern = FillPatternType.SOLID_FOREGROUND;
style1.Alignment = HorizontalAlignment.CENTER;
style1.VerticalAlignment = VerticalAlignment.CENTER;
var font = _workBook.CreateFont();
font.Color = HSSFColor.WHITE.index;
style1.SetFont(font);
oCell.CellStyle = style1;
var name = column.ColumnName;
oCell.SetCellValue(name.ToString());
_col++;
}
///// header belong to rows
_row++;
}
private void CreateHeader(ISheet sheet)
{
CreateHeader(sheet, null);
}
public ISheet CreateSheet()
{
return CreateSheet(null);
}
public ISheet CreateSheet(DataColumnCollection columns)
{
_wbSheet = _workBook.CreateSheet((_sheet + 1).ToString());
CreateHeader(_wbSheet, columns);
_sheet++;
return _wbSheet;
}
public void SetRowValue(DataRowCollection rows, ISheet sheet)
{
_wbSheet = GetSheet(sheet);
foreach (DataRow row in rows)
{
SetRowValue(row);
}
}
public void SetRowValue(DataRowCollection rows)
{
SetRowValue(rows, null);
}
public void SetRowValue(DataRow row)
{
// create a new sheet
if (_row % _sheetRowNum == 0)
{
CreateSheet();
}
var oRow = _wbSheet.CreateRow(_row % _sheetRowNum);
var obj = string.Empty;
var cell = 0;
foreach (DataColumn column in _columns)
{
obj = row[column.ColumnName].ToString();
oRow.CreateCell(cell).SetCellValue(obj);
cell++;
}
_row++;
}
public void SetProtectPassword(string password, string username)
{
_workBook.WriteProtectWorkbook(password, username);
}
public void SaveAs(string filePath)
{
if (File.Exists(filePath)) File.Delete(filePath);
var file = new FileStream(filePath, FileMode.Create);
_workBook.Write(file);
file.Close();
}
}
}

下面給出小Demo共參考:
復制代碼 代碼如下:

public void DataTableToExcel(DataTable dt,string path)
{
//instance excel object
//Excel excel = new Excel(65536);
Excel excel = new Excel();
//create a sheet
excel.CreateSheet(dt.Columns);
//write value into rows
//excel.SetRowValue(dt.Rows);
foreach (DataRow row in dt.Rows)
{
excel.SetRowValue(row);
}
// set excel protected
excel.SetProtectPassword("etimes2011@", "baiyi");
// save excel file to local
excel.SaveAs(path);
}

缺點:如果要導入到Excel中的數據量較多時(幾十萬或者幾百萬行),全部一次性放到DataTable中可能會對內存消耗很大,建議每次導入的數據最好不要超過1000條,可采取分頁查詢的方式將數據導入Excel中。

優點:1997-2003版本的xls中每個表單最大只支持65536行,2010可以支持1048576行,考慮到客戶機上安裝的版本不一樣,故Excel對象每個表單最大支持65536行,當表單到達最大行數時,Excel對象內部會自動創建新表單,在往Excel中寫數據的時候不用考慮這一點,這樣調用的時候更為方便
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日日草夜夜 | 亚洲午夜久久久精品一区二区三区 | 黄色片在线观看网站 | 91av网址| 99re热视频这里只精品 | 亚洲男人的天堂在线视频 | 鲁人人人鲁人人鲁精品 | 欧美黄色一级生活片 | 国产精品中文在线 | 欧美在线一级 | 3xxx| 一级一级一级一级毛片 | 精品亚洲综合 | av在线免费播放 | 性欧美xxxx极品摘花 | 操操操日日日干干干 | 欧美视频一级 | 成人在线97| 欧美日韩国产综合网 | 毛片成人网 | 久久最新免费视频 | 五月婷婷第四色 | 毛片大全免费 | 午夜视频你懂的 | 黄色成人小视频 | 羞羞的小视频 | 色阁五月| 国产一区二区三区精品在线观看 | 亚洲精品91 | 亚州精品在线视频 | 久久一区三区 | 免费观看一区 | 91网视频在线观看 | 国产一级一片免费播放 | 免费在线观看亚洲 | 黄色18网站 | 精品国产一区二区三区久久久狼牙 | 青久草视频 | 成人永久免费视频 | 青青国产在线视频 | 一级毛片在线观看免费 |