欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#如何將DataTable導(dǎo)出到Excel解決方案

 更新時(shí)間:2012年11月22日 17:44:48   作者:  
由于公司項(xiàng)目中需要將系統(tǒng)內(nèi)用戶操作的所有日志進(jìn)行轉(zhuǎn)存?zhèn)浞荩紤]到以后可能還需要還原,所以最后決定將日志數(shù)據(jù)備份到Excel中
最近,由于公司項(xiàng)目中需要將系統(tǒng)內(nèi)用戶操作的所有日志進(jìn)行轉(zhuǎn)存?zhèn)浞?,考慮到以后可能還需要還原,所以最后決定將日志數(shù)據(jù)備份到Excel中。

下面是我項(xiàng)目當(dāng)中Excel.cs這個(gè)類的全部代碼,通過這個(gè)類可以很容易地將DataTable中的數(shù)據(jù)導(dǎo)入到Excel方法中。

首先,必須要下載NPOI.dll這個(gè)程序集,
類代碼如下:
復(fù)制代碼 代碼如下:

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>
/// 實(shí)例方法
/// </summary>
/// <param name="sheetRowNum">單個(gè)表單允許的最大行數(shù)</param>
public Excel(int sheetRowNum)
{
_sheetRowNum = sheetRowNum;
InstanceWorkBook();
}
/// <summary>
/// 實(shí)例方法
/// </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共參考:
復(fù)制代碼 代碼如下:

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);
}

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

優(yōu)點(diǎn):1997-2003版本的xls中每個(gè)表單最大只支持65536行,2010可以支持1048576行,考慮到客戶機(jī)上安裝的版本不一樣,故Excel對(duì)象每個(gè)表單最大支持65536行,當(dāng)表單到達(dá)最大行數(shù)時(shí),Excel對(duì)象內(nèi)部會(huì)自動(dòng)創(chuàng)建新表單,在往Excel中寫數(shù)據(jù)的時(shí)候不用考慮這一點(diǎn),這樣調(diào)用的時(shí)候更為方便

相關(guān)文章

  • Unity存儲(chǔ)游戲數(shù)據(jù)的多種方法小結(jié)

    Unity存儲(chǔ)游戲數(shù)據(jù)的多種方法小結(jié)

    這篇文章主要介紹了Unity存儲(chǔ)游戲數(shù)據(jù)的幾種方法,在游戲開發(fā)中,存儲(chǔ)游戲數(shù)據(jù)是非常重要的,因?yàn)橛螒驍?shù)據(jù)決定了游戲的各個(gè)方面,例如游戲的進(jìn)度、玩家的成就、游戲的設(shè)置,需要的朋友可以參考下
    2023-02-02
  • C#中使用資源的方法分析

    C#中使用資源的方法分析

    這篇文章主要介紹了C#中使用資源的方法,較為詳細(xì)的對(duì)比分析了C#中使用資源的幾種常用方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2014-12-12
  • C# Winform下載文件并顯示進(jìn)度條的實(shí)現(xiàn)代碼

    C# Winform下載文件并顯示進(jìn)度條的實(shí)現(xiàn)代碼

    本來是要研究怎樣判斷下載完成,結(jié)果找到這個(gè)方法,可以在這個(gè)方法完成之后提示下載完成,需要的朋友可以參考下
    2014-07-07
  • C#中is和as用法實(shí)例分析

    C#中is和as用法實(shí)例分析

    這篇文章主要介紹了C#中is和as用法實(shí)例分析,需要的朋友可以參考下
    2014-08-08
  • 同時(shí)兼容JS和C#的RSA加密解密算法詳解(對(duì)web提交的數(shù)據(jù)加密傳輸)

    同時(shí)兼容JS和C#的RSA加密解密算法詳解(對(duì)web提交的數(shù)據(jù)加密傳輸)

    這篇文章主要給大家介紹了關(guān)于同時(shí)兼容JS和C#的RSA加密解密算法,通過該算法可以對(duì)web提交的數(shù)據(jù)進(jìn)行加密傳輸,文中通過圖文及示例代碼介紹的非常詳細(xì),需要的朋友們可以參考借鑒,下面來一起看看吧。
    2017-07-07
  • C#查找對(duì)象在ArrayList中出現(xiàn)位置的方法

    C#查找對(duì)象在ArrayList中出現(xiàn)位置的方法

    這篇文章主要介紹了C#查找對(duì)象在ArrayList中出現(xiàn)位置的方法,涉及C#中IndexOf方法的使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-04-04
  • c#判斷email地址是否為合法

    c#判斷email地址是否為合法

    輸入email地址使用c#語(yǔ)言檢測(cè)出email地址是否是合法的,這篇文章主要介紹了c#判斷email地址是否為合法的相關(guān)資料,需要的朋友可以參考下
    2016-07-07
  • C#實(shí)現(xiàn)提高xml讀寫速度的方法

    C#實(shí)現(xiàn)提高xml讀寫速度的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)提高xml讀寫速度的方法,并且針對(duì)各類文件的讀寫做了較為細(xì)致的分析,非常實(shí)用,需要的朋友可以參考下
    2014-11-11
  • 最新評(píng)論