亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > 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中寫數據的時候不用考慮這一點,這樣調用的時候更為方便
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
92国产精品久久久久首页| 欧美一级大片在线观看| 亚洲jizzjizz日本少妇| 日本免费一区二区三区视频观看| 国产91精品高潮白浆喷水| 九九精品视频在线| 国内精品久久久久久| 欧美xxxx做受欧美.88| 国产精品对白刺激| 欧美丝袜第一区| 欧美激情一区二区久久久| 欧美国产日产韩国视频| 中文字幕日韩av综合精品| 日韩毛片在线观看| 不卡中文字幕av| 成人精品视频在线| 色老头一区二区三区在线观看| 日韩av中文字幕在线| 国产精品久久久久免费a∨大胸| 日韩精品在线影院| 色妞久久福利网| 国产视频丨精品|在线观看| 久久色免费在线视频| 久久久中精品2020中文| 国产亚洲一级高清| 97国产成人精品视频| 日韩福利在线播放| 在线观看国产精品淫| 中文字幕欧美亚洲| 中文字幕亚洲一区| 国产这里只有精品| 青青在线视频一区二区三区| 国产精品久久久久aaaa九色| 久久人人看视频| 国产成人啪精品视频免费网| 亚洲国产欧美一区二区三区久久| 欧美性在线观看| 日韩高清免费在线| 国产成人精品日本亚洲专区61| 亚洲第一av网站| 孩xxxx性bbbb欧美| 久久综合久中文字幕青草| 亚洲乱码一区二区| 97婷婷涩涩精品一区| 色综久久综合桃花网| 日韩视频免费在线观看| 91视频九色网站| 精品久久久久久久久久国产| 国产精品吹潮在线观看| 欧美性视频精品| 欧美大胆在线视频| 福利一区福利二区微拍刺激| 欧美午夜激情视频| 国产精品v片在线观看不卡| 久久视频国产精品免费视频在线| 亚洲精品一区二区网址| 亚洲第一av网| 国产精品99久久久久久久久| 中文字幕视频在线免费欧美日韩综合在线看| 欧美黑人一级爽快片淫片高清| 国产一区二区av| 亚洲最新中文字幕| 国产亚洲欧洲在线| 奇米成人av国产一区二区三区| 久久视频在线看| 午夜精品一区二区三区在线视频| 日韩精品在线免费观看| 欧美激情视频一区二区| 91国产在线精品| 欧美在线观看一区二区三区| 精品视频—区二区三区免费| 日韩成人av在线播放| 91国产视频在线播放| 亚洲精品自在久久| 在线电影av不卡网址| 国自产精品手机在线观看视频| 国产精品精品久久久久久| 欧美三级免费观看| 中文字幕久精品免费视频| 亚洲一区二区自拍| 777777777亚洲妇女| 欧美日韩中文在线观看| 日韩中文字幕国产| 日韩在线播放一区| 欧美最猛黑人xxxx黑人猛叫黄| 国产一区二区日韩精品欧美精品| 欧日韩不卡在线视频| 国产日韩欧美在线视频观看| 国产精品久久中文| 国产欧美精品xxxx另类| 欧美激情视频一区二区三区不卡| 日韩在线观看成人| 日本人成精品视频在线| 欧美激情视频在线免费观看 欧美视频免费一| 久久久精品一区二区| 亚洲精品久久久久久下一站| 欧美大片在线免费观看| 国产91免费观看| 正在播放欧美一区| 日韩精品中文字幕在线观看| 中文字幕亚洲欧美一区二区三区| 日本一区二三区好的精华液| 国产视频精品va久久久久久| 欧美性猛交99久久久久99按摩| 久久大大胆人体| 美女性感视频久久久| 亚洲精品美女在线| 欧美激情精品久久久久久蜜臀| 91成人在线观看国产| 狠狠躁夜夜躁人人爽天天天天97| 国产午夜精品麻豆| 青草热久免费精品视频| 国内精品在线一区| 亚洲影院在线看| 色久欧美在线视频观看| 欧美亚洲国产另类| 精品中文字幕在线观看| 日韩中文字幕网站| 91国偷自产一区二区三区的观看方式| 日韩三级成人av网| 久久久成人的性感天堂| 亚洲国产精品久久91精品| 久久91亚洲精品中文字幕| 亚洲va码欧洲m码| 日本免费一区二区三区视频观看| 亚洲精品国偷自产在线99热| 色婷婷综合久久久久中文字幕1| 国产精品成人一区二区三区吃奶| 亚洲精品综合久久中文字幕| 精品性高朝久久久久久久| 国产精品美女www爽爽爽视频| 成人黄色影片在线| 久久久女女女女999久久| 久久九九精品99国产精品| 欧美激情aaaa| 色婷婷综合久久久久中文字幕1| 日韩在线观看高清| 国产精欧美一区二区三区| 亚洲精品永久免费精品| 久久精品视频99| 黄色成人在线免费| 欧美夫妻性生活xx| 欧美成人午夜激情在线| 亚洲色图综合久久| 亚洲精品一区二区网址| 亚洲国产成人久久综合| 丝袜一区二区三区| 久热爱精品视频线路一| 日韩大胆人体377p| 92国产精品视频| 午夜精品久久17c| 国产日本欧美一区二区三区在线| 色视频www在线播放国产成人| xvideos国产精品| 欧美黑人狂野猛交老妇| 97超级碰碰碰久久久| 久久精品视频导航| 亚洲九九九在线观看| 搡老女人一区二区三区视频tv| 欧美性xxxxxxx| 亚洲人高潮女人毛茸茸| 日韩av电影在线免费播放| 久久综合电影一区| 日韩经典中文字幕在线观看|