C# NPOI导出datatable----Excel模板画图表

1、创建Excel模板

2、安装NPOI管理包

3、创建工作簿 (XLSX和XLS步骤一样,以XLS为例)

IWorkbook workbook = null;

string time = DateTime.Now.ToString("yyyyMMddHHmmss");

string excelTempPath = Application.StartupPath + @"\Excel\分析模板.xls";//分析模板

string path = Application.StartupPath + @"\Excel\分析文件" + time + ".xls";//保存路径

//读取Excel模板

using (FileStream fs = new FileStream(excelTempPath, FileMode.Open, FileAccess.Read))

{

workbook = new HSSFWorkbook(fs);

}

//获取sheet模板

ISheet sheet1 = workbook.GetSheetAt(0);

//将DataSet导出为Excel

4、讲datatable数据写入Excel

//将DataSet导出为Excel

int rowCount = dt.Rows.Count;//行数

int columnCount = dt.Columns.Count;//列数

//设置列头

IRow row = sheet1.CreateRow(0);//excel第一行设为列头

for (int c = 0; c < columnCount; c++)

{

ICell cell = row.CreateCell(c);

cell.SetCellValue(dt.Columnsc.ColumnName);

}

//设置每行每列的单元格,

for (int i = 0; i < rowCount; i++)

{

row = sheet1.CreateRow(i + 1);

for (int j = 0; j < columnCount; j++)

{

ICell cell = row.CreateCell(j);//excel第二行开始写入数据

if (dt.Rowsij.ToString().Length > 0)//判断分数是否为空

{//写入数值类型

cell.SetCellValue((double)Convert.ToDecimal((dt.Rowsij)));

}

else

{//写入文本类型

cell.SetCellValue(dt.Rowsij.ToString());

}

}

}

workbook.SetSheetName(0, dt.TableName);//修改excel页名为datatable表名

5、向文件输出数据

//向outPath输出数据

using (FileStream fs = File.Open(path, FileMode.Create, FileAccess.Write))

{

workbook.Write(fs);//向打开的这个xls文件中写入数据

fs.Close();

}

相关推荐
Hello:CodeWorld3 分钟前
深入浅出 C++:静态多态与动态多态的业务应用场景与源码级实战
开发语言·c++·架构
星恒随风4 分钟前
C++入门(一):第一个 C++ 程序、命名空间、输入输出和缺省参数
开发语言·c++·笔记·学习
AI人工智能+电脑小能手4 分钟前
【大白话说Java面试题 第94题】【Mysql篇】第24题:什么是单路排序?什么是双路排序??
java·开发语言·数据库·mysql·面试·排序算法
于先生吖4 分钟前
Java分账体系设计,网约车行程计费与到店线下结账一体化后端开发实战
java·开发语言
WarPigs5 分钟前
C# EntityFramework笔记
数据库·c#
thisiszdy8 分钟前
<C++&C#> lambda表达式
java·c++·c#
Cloud_Shy61812 分钟前
解读《Effective Python 3rd Edition》:从练气到老魔(第三章 Item 17 - 20)
开发语言·笔记·python
三品吉他手会点灯13 分钟前
C语言学习笔记 - 42.数据类型 - scanf函数深度解析
c语言·开发语言·笔记·学习
隔窗听雨眠23 分钟前
ORM框架选型指南:MyBatis与Hibernate的全面对比
java·开发语言·数据库
-凌凌漆-27 分钟前
【Qt】C++中protected与private的区别
开发语言·c++·qt