C#使用NPOI导出Excel文件

fb064d10d439fe7127450ed74fa0757b.png

欢迎您成为我的读者,希望这篇文章能给你一些帮助。

前言

今天咱们一起来看看在C#中如何使用NPOI第三方控件进行数据的导出。

关于NPOI插件网上资料很多,大家感兴趣的可以去看看。

本文使用的版本是NPOI 2.5.1。

大家可在包管理器NuGet或者下面网址进行下载。

http://npoi.codeplex.com/
快速下载地址:
//files.cnblogs.com/files/netxiaohui/npoi.2.5.1.zip

很多时候,我们在进行数据导出到Excel文件时,在windows平台需要使用到office组件才可以成功导出,也就是说电脑很多时候都必须安装office才可以。今天分享的这个组件,可以在目标主机不安装office的情况下,对Word或Excel进行读写操作。

NPOI的优势

  • 开源,可以完全免费使用

  • 包含大部分EXCEL的特性

  • 支持处理的文件格式包括(xls/xlsx/docx)

  • 同时支持导入导出

  • 基于.net 2.0/4.0也支持xlsx和docx格式

  • 不需要在服务器或目标主机安装office

  • 它不仅对Excel进行操作,可以对doc,ppt文件进行操作

NPOI内部构成

NPOI是一个开源的C#读取Excel、Word等微软OLE2组件文件的项目。

在使用NPOI的过程中,有一些名称需要提前了解下。

Workbook工作薄 一个文件包含一个工作簿,一个工作簿可以包含若干个工作表Sheet。

Sheet工作表

HSSFWorkbook用于处理xls文件类型的NPOI操作类,继承自IWorkbook。

XSSFWorkbook处理xlsx文件类型的NPOI操作类,也继承自IWorkbook。

操作xlsx文件进行数据导出工作时,主要有以下几个步骤需要注意。

1、声明XSSFWorkbook实例。

2、利用声明并实例化的工作簿创建其工作表。

3、写入Excel表头和表数据

4、将实例化的工作簿写入流文件中。

实际的导出工作就是上面说的四步,但是在内部需要具体进行一些表格样式、输出字体样式的调整。

具体代码如下:

using (FileStream fs = new FileStream(sfd.FileName, FileMode.OpenOrCreate, FileAccess.ReadWrite)){XSSFWorkbook workbook = new XSSFWorkbook();ISheet sheet = workbook.CreateSheet("Sheet1");string[] excelHeader = new string[] {"点名称","编号", "时间", "埋深(m)", "水深(m)", "测试01", "测试02", "测试03", "测试04", "测试05", "测试06", "测试06", "测试07", "测试08", "测试09"};IRow headerRow = sheet.CreateRow(0);for (int i = 0; i < excelHeader.Length; i++){headerRow.CreateCell(i).SetCellValue(excelHeader[i]);}int count = mpInfoDictionary.Count;for (int i = 0; i < count; i++){MeasurementPointInfo mpi = mpInfoDictionary[i];IRow row = sheet.CreateRow(i + 1);row.CreateCell(0).SetCellValue("名称");row.CreateCell(1).SetCellValue(mpi.nSeq);row.CreateCell(2).SetCellValue(mpi.nDate.ToString());row.CreateCell(3).SetCellValue(mpi.dbDepth);row.CreateCell(4).SetCellValue(mpi.dbWaterDepth);row.CreateCell(5).SetCellValue(mpi.dbCPTDInfo);row.CreateCell(6).SetCellValue(mpi.dbCPTDOffInfo);row.CreateCell(7).SetCellValue(mpi.dbOneDragDisplaceDSe);row.CreateCell(8).SetCellValue(mpi.dbOneDragDisplaceDSn);row.CreateCell(9).SetCellValue(mpi.dbOneDragDisplaceDSu);row.CreateCell(10).SetCellValue(mpi.dbCPInfo);row.CreateCell(11).SetCellValue(mpi.dbCPOffInfo);row.CreateCell(12).SetCellValue(mpi.dbDisplaceSE);row.CreateCell(13).SetCellValue(mpi.dbDisplaceSN);row.CreateCell(14).SetCellValue(mpi.dbDisplaceSU);    }workbook.Write(fs);           //写入到Excel中          }

可以导出如下所示表格:

f910d5495d661e6d1ec27a0148573a60.png

寄语

人生短暂,我不想去追求自己看不见的,我只想抓住我能看得见的。

原创不易,给个关注。

我是阿辉,感谢您的阅读,如果对你有帮助,麻烦点赞、转发  谢谢。

很高兴能和您成为朋友。

32070bc3c3ec0dded30de8c661ea5dbf.png

37be5cec0b6cbc884e31a66f2049798b.png

推荐阅读

分享给同做程序员的你我他

毕业四年,我当初是如何走上编程这条路的!

物联网工程专业的迷茫与抉择

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/291146.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android之ActivityLifecycleCallbacks的得到当前的activity的状态

1、ActivityLifecycleCallbacks的介绍 Application通过此接口提供了一套回调方法,用于让开发者对Activity的生命周期事件进行集中处理,注意是在Application里面,路径如下 android.app.Application.ActivityLifecycleCallbacks要求API 14+ (Android 4.0+) ActivityLifecyc…

oracle使用max提升效率,Oracle调优之利用max与leftjoin来进行不同表之间匹配

需求有两个不同的表&#xff0c;A表是基础数据&#xff0c;B表根据A表的某个不重复关键字加其他一些条件查询出一条或几条数据&#xff0c;取其中一条数据。并且利用此数据某个关键字再在B表中查询下一层级数据&#xff0c;最终将A表的对应一条数据&#xff0c;B表查询出的两条…

开放产品开发(OPD):Archi 汉化工具下载

在OPD中&#xff0c;我们使用了ArchiMate 作为架构语言&#xff0c;这是一个高层、简单的描述语言&#xff0c;之前我也写过一系列相关的文字&#xff0c;架构语言ArchiMate &#xff0d; 开篇&#xff1a;企业架构语言ArchiMate介绍架构语言ArchiMate &#xff0d; 语言结构&a…

【数据库中间件】MyCat分表分库规则实现

2019独角兽企业重金招聘Python工程师标准>>> /*** * 先根据截取字段的日期分组&#xff0c;再根据字段值数据按天入表 * author Fx_demon * */ public class PartitionBySubstringRangeDateDay extends AbstractPartitionAlgorithm implements RuleAlgo…

Redis: Useful commands

SELECT X - Select database (the X must be int) CONFIG GET databases - Get databases numberINFO keyspace - List Databases info LUSHDB - Removes data from your connections CURRENT database. FLUSHALL - Removes data from ALL databases.查看数据…

svn之check out没有下载so文件原因和解决办法

1、问题 linux 环境 svn checkout 发现少了so文件 2、解决办法 然后去看出我在windows上面svn checkout下来的项目&#xff0c;发现有so文件&#xff0c;然后再去查看&#xff0c;我把这个项目svn commit到另外一个svn路径的时候有没有提交so文件&#xff0c;结果发现真的没…

[C# 项目实战]: 制作一个备忘录(经典)

01—概述前几天群里有人问如何制作备忘录&#xff0c;感觉这样一个小实例挺适合新手们入门学习使用&#xff0c;所以就抽空做了出来。界面如下图&#xff1a;这个备忘录主要包括了如下功能&#xff1a;① 备忘录信息的增、删、改、查&#xff1b;② 备忘录时间到了以后进行语音…

RedHat 5.4下构建postfix全功能电子邮(七)-extmail extman平台-(下集)

2019独角兽企业重金招聘Python工程师标准>>> RedHat 5.4下构建postfix全功能电子邮&#xff08;七&#xff09;-extmail extman平台-&#xff08;下集&#xff09; 三、设置邮件系统的图形化日志信息 [rootmail ~]# ln -sf /usr/local/apache2/htdocs/extman/addon…

Android之moveTaskToBack()方法实现手动隐藏当前Activity

1、moveTaskToBack()方法说明 moveTaskToBack()方法&#xff1a;在activity中调用 moveTaskToBack (booleannonRoot)方法即可将activity 退到后台&#xff0c;注意不是finish()退出&#xff0c;按下返回键是退出 参数说明&#xff1a; 参数为false——代表只有当前activity是t…

JNI中的内存管理(转)

源&#xff1a;JNI中的内存管理 JNI 编程简介 JNI&#xff0c;Java Native Interface&#xff0c;是 native code 的编程接口。JNI 使 Java 代码程序可以与 native code 交互——在 Java 程序中调用 native code&#xff1b;在 native code 中嵌入 Java 虚拟机调用 Java 的代码…

C# 异步方法的异常处理

在使用异步方法时&#xff0c;应该知道错误的一些特殊处理方式。所有 ErrorHandling 示例的代码都使用了如下名称空间&#xff1a;SystemSystem.Threading.Tasks从一个简单的方法开始&#xff0c;它在延迟后抛出一个异常&#xff1a;static async Task ThrowAfter(int ms, stri…

oracle 创建日志文件,oracle创建日志文件

一团网资讯一团资讯 > oracle > oracle创建日志文件oracle创建日志文件2018-04-14 15:39:48 发布者&#xff1a;来源网络创建日志文件的语法如下&#xff1a;alter database database_name add logfile[group group_number](file_name[,file_name[,...]])[SIZE numbe…

Mark Down 使用实例

为什么80%的码农都做不了架构师&#xff1f;>>> Mark Down 使用实例 MarkDown是一个非常轻量级的 【标记语言】&#xff0c;有点有很多&#xff0c;书写比较快速&#xff0c;学习成本低&#xff0c;统一的排版模式&#xff0c;可导出 PDF HTML 等文档格式&#xff…

Android之在后台不显示activity方法

1、设置excludeFromRecents Androidmanifest.xml&#xff0c;设置Activity的属性&#xff1a;Android:excludeFromRecents"true"true时不显示&#xff1b;false默认显示。 2、start activity intent flag startactivity的时候用intent flag:FLAG_ACTIVITY_EXCLUDE_FR…

教育管理系统——android家长客户端

最近做了一个android的小项目&#xff0c;服务器端已经搭建好了&#xff0c;使用了spring MVC作为后端技术&#xff0c;发布了一系列web接口来接受客户端提交的数据和返回客户端请求的数据&#xff0c;web端使用了ext js来作为前端技术。同时还需要一个android客户端和ios客户端…

JoySSL付费版证书的优势

JoySSL付费版证书相比免费版有很多优势。首先&#xff0c;付费版证书通常由权威的CA&#xff08;证书颁发机构&#xff09;签发&#xff0c;在浏览器和操作系统中具有99.99%的兼容性&#xff0c;被主流浏览器如Chrome、Firefox、Safari和Edge等广泛支持和认可。这确保了无论用户…

Git命令集十三——快照操作

2019独角兽企业重金招聘Python工程师标准>>> Git命令集十三——快照操作 Git工具中提供了一个stash命令&#xff0c;这个命令的作用是创建快照。快照主要的用途是将当前未更新到缓存区的修改进行入栈保存&#xff0c;创建快照后&#xff0c;Git的状态会变回上一次提…

Asp.net core IdentityServer4与传统基于角色的权限系统的集成

img写在前面因为最近在忙别的&#xff0c;好久没水文了 今天来水一篇&#xff1b;在学习或者做权限系统技术选型的过程中&#xff0c;经常有朋友有这样的疑问 &#xff1a;“IdentityServer4的能不能做到与传统基于角色的权限系统集成呢&#xff1f;”“我的公司有几百个接口&a…

oracle 快捷 企业,Oracle自治数据库提供APEX 20.1,助企业快速构建应用

Oracle自治数据库(Oracle Autonomous Database)现已提供Oracle APEX 20.1&#xff0c;Oracle Application Express(APEX)是一个低代码应用开发平台&#xff0c;随附在所有Oracle数据库当中&#xff0c;企业也可以通过所有Oracle数据库云服务来使用&#xff0c;包括Oracle自治数…

【转】CSS样式覆盖规则

大家都知道CSS的全称叫做“层叠样式表”&#xff0c;但估计很多人都不知道“层叠”二字的含义。其实&#xff0c;“层叠”指的就是样式的覆盖&#xff0c;当一个元素被运用上多种样式&#xff0c;并且出现重名的样式属性时&#xff0c;浏览器必须从中选择一个属性值&#xff0c…