easyexcel多个sheet导入_NPOI实现多个dt数据导入一个EXCEL的多SHEET | 学步园

///

/// 导出EXCEL

///

/// 所有表名

/// 导出文件名

public static void ExportEasy(string[] sTableNames,string strFileName,string sStartDate,string sEndDate,string sStartHour,string sEndHour)

{

HSSFWorkbook workbook = new HSSFWorkbook();

for (int iTCount = 0; iTCount < sTableNames.Length; iTCount++)

{

DBTables dbs = new DBTables();

string[] sFieldName=new string[3];

List lstFieldName = new List();

lstFieldName = dbs.GetColumnFieldList(sTableNames[iTCount]);

string sSql="";

if (lstFieldName.Contains("结束时间"))

{

sSql = "SELECT * FROM [" + sTableNames[iTCount] + "] WHERE 日期>='" + sStartDate + "' AND 日期<='" + sEndDate + "' AND 结束时间>=" + sStartHour + "AND 结束时间<=" + sEndDate;

}

else

{

sSql = "SELECT * FROM [" + sTableNames[iTCount] + "] WHERE 日期>='" + sStartDate + "' AND 日期<='" + sEndDate + "' AND 时间>=" + sStartHour + "AND 时间<=" + sEndDate;

}

DataSet ds = new DataSet();

string[] s = { sTableNames[iTCount] };

SqlHelper.FillDataset(Common.GetConnect(), CommandType.Text, sSql, ds, s);

DataTable dt = ds.Tables[sTableNames[iTCount]];

HSSFSheet sheet = workbook.CreateSheet(sTableNames[iTCount]);

//填充表头

HSSFRow dataRow = sheet.CreateRow(0);

foreach (DataColumn column in dt.Columns)

{

dataRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);

}

//填充内容

for (int i = 0; i < dt.Rows.Count; i++)

{

dataRow = sheet.CreateRow(i + 1);

for (int j = 0; j < dt.Columns.Count; j++)

{

dataRow.CreateCell(j).SetCellValue(dt.Rows[i][j].ToString());

}

}

}

//保存

using (MemoryStream ms = new MemoryStream())

{

using (FileStream fs = new FileStream(strFileName, FileMode.Create, FileAccess.Write))

{

workbook.Write(fs);

}

}

}

///

/// 导出EXCEL,可以导出多个sheet

///

/// 原始数据数组类型

/// 路径

public static void ExportEasy(DataTable[] dtSources, string strFileName)

{

HSSFWorkbook workbook = new HSSFWorkbook();

for (int k = 0; k < dtSources.Length; k++)

{

HSSFSheet sheet = workbook.CreateSheet(dtSources[k].TableName.ToString());

//填充表头

HSSFRow dataRow = sheet.CreateRow(0);

foreach (DataColumn column in dtSources[k].Columns)

{

dataRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);

}

//填充内容

for (int i = 0; i < dtSources[k].Rows.Count; i++)

{

dataRow = sheet.CreateRow(i + 1);

for (int j = 0; j < dtSources[k].Columns.Count; j++)

{

dataRow.CreateCell(j).SetCellValue(dtSources[k].Rows[i][j].ToString());

}

}

}

//保存

using (MemoryStream ms = new MemoryStream())

{

using (FileStream fs = new FileStream(strFileName, FileMode.Create, FileAccess.Write))

{

workbook.Write(fs);

}

}

}

///

/// 导出单个EXCEL

///

///

///

public static void ExportEasy(DataTable dtSource, string strFileName)

{

HSSFWorkbook workbook = new HSSFWorkbook();

HSSFSheet sheet = workbook.CreateSheet();

//填充表头

HSSFRow dataRow = sheet.CreateRow(0);

foreach (DataColumn column in dtSource.Columns)

{

dataRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);

}

//填充内容

for (int i = 0; i < dtSource.Rows.Count; i++)

{

dataRow = sheet.CreateRow(i + 1);

for (int j = 0; j < dtSource.Columns.Count; j++)

{

dataRow.CreateCell(j).SetCellValue(dtSource.Rows[i][j].ToString());

}

}

//保存

using (MemoryStream ms = new MemoryStream())

{

using (FileStream fs = new FileStream(strFileName, FileMode.Create, FileAccess.Write))

{

workbook.Write(fs);

}

}

//workbook.Dispose();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值