NPOI根据Excel模板生成原生的Excel文件实例

23 篇文章 0 订阅

上周完成了一个报表小项目,使用开源组件NPOI作为主要组件。之所以采用第三方的开源组件而不使用COM或微软提供的API,原因就不多说了,大家懂的。

在此分享NPOI的一个应用,利用Excel模板生成excel文件。这正是NPOI强于Myxls之处。

具体步骤如下:

一、准备数据

 

二、新建一个项目,结构如下:

邀月工作室

模板文件如下:

 

三、预览结果:

邀月工作室

四、修正模板

重新生成:

邀月工作室

循环每个Cell,如果为0,则置为空

邀月工作室

其实NPOI在实际项目中可以生成更加复杂的图表,如下图:

 

简单示例代码下载:
下载二

下载一

 

 

邀月注:本文版权由邀月和CSDN共同所有,转载请注明出处。
助人等于自助!   3w@live.cn


使用NPOI生成Excel模板并具备下拉选项的步骤如下: 1.添加NPOI依赖包 在项目中添加NPOI的依赖包,可以通过Maven进行添加,也可以手动下载添加到项目中。 2.创建Excel模板文件 使用NPOI创建一个新的Excel文件,并创建一个Sheet。在Sheet中添加需要的表头和数据列。 3.设置下拉选项 使用NPOI提供的方法,设置需要添加下拉选项的单元格的数据校验规则。下面是示例代码: ``` //获取当前Sheet ISheet sheet = workbook.GetSheet("Sheet1"); //创建下拉列表数据 string[] data = new string[] { "选项1", "选项2", "选项3" }; var validation = sheet.GetDataValidationHelper().CreateValidation( sheet.GetDataValidationHelper().CreateExplicitListConstraint(data), new CellRangeAddressList(1, 100, 0, 0)); //设置下拉选项的单元格范围 //设置下拉选项的单元格样式 var style = workbook.CreateCellStyle(); style.DataFormat = HSSFDataFormat.GetBuiltinFormat("0"); style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center; //将数据校验规则应用到单元格中 sheet.AddValidationData(validation); sheet.GetRow(1).CreateCell(0).CellStyle = style; ``` 4.保存Excel模板文件 使用NPOI提供的方法,将生成Excel模板文件保存到本地或者输出到浏览器中供用户下载。下面是示例代码: ``` //保存Excel文件 using (var fileStream = new FileStream(filePath, FileMode.Create, FileAccess.Write)) { workbook.Write(fileStream); } ``` 完整的示例代码如下: ``` //创建Excel文件 var workbook = new HSSFWorkbook(); var sheet = workbook.CreateSheet("Sheet1"); //创建表头 var headerRow = sheet.CreateRow(0); headerRow.CreateCell(0).SetCellValue("选项"); //创建下拉列表数据 string[] data = new string[] { "选项1", "选项2", "选项3" }; var validation = sheet.GetDataValidationHelper().CreateValidation( sheet.GetDataValidationHelper().CreateExplicitListConstraint(data), new CellRangeAddressList(1, 100, 0, 0)); //设置下拉选项的单元格范围 //设置下拉选项的单元格样式 var style = workbook.CreateCellStyle(); style.DataFormat = HSSFDataFormat.GetBuiltinFormat("0"); style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center; //将数据校验规则应用到单元格中 sheet.AddValidationData(validation); //添加数据行 for (int i = 1; i <= 10; i++) { var dataRow = sheet.CreateRow(i); dataRow.CreateCell(0).CellStyle = style; } //保存Excel文件 using (var fileStream = new FileStream(filePath, FileMode.Create, FileAccess.Write)) { workbook.Write(fileStream); } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值