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.Columns[c].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.Rows[i][j].ToString().Length > 0)//判断分数是否为空

{//写入数值类型

cell.SetCellValue((double)Convert.ToDecimal((dt.Rows[i][j])));

}

else

{//写入文本类型

cell.SetCellValue(dt.Rows[i][j].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();

}

相关推荐
代码游侠14 小时前
学习笔记——ESP8266 WiFi模块
服务器·c语言·开发语言·数据结构·算法
行者9615 小时前
Flutter跨平台开发适配OpenHarmony:进度条组件的深度实践
开发语言·前端·flutter·harmonyos·鸿蒙
DYS_房东的猫15 小时前
《 C++ 零基础入门教程》第3章:结构体与类 —— 用面向对象组织代码
开发语言·c++
向量引擎15 小时前
复刻“疯狂的鸽子”?用Python调用Sora2与Gemini-3-Pro实现全自动热点视频流水线(附源码解析)
开发语言·人工智能·python·gpt·ai·ai编程·api调用
CoderCodingNo15 小时前
【GESP】C++五级练习(贪心思想考点) luogu-P1115 最大子段和
开发语言·c++·算法
a程序小傲15 小时前
得物Java面试被问:边缘计算的数据同步和计算卸载
java·开发语言·数据库·后端·面试·golang·边缘计算
唐青枫15 小时前
C#.NET ConcurrentBag<T> 设计原理与使用场景
c#·.net
lly20240615 小时前
PHP 运算符
开发语言
txinyu的博客15 小时前
make_shraed & make_unique 替代了new ? 什么场景使用new
开发语言·c++·算法
不会c嘎嘎15 小时前
QT中的常用控件(五)
服务器·开发语言·qt