当前位置: 首页 > 编程日记 > 正文

NPOI读写Excel

1、整个Excel表格叫做工作表:WorkBook(工作薄),包含的叫页(工作表):Sheet;行:Row;单元格Cell。

2、NPOI是POI的C#版本,NPOI的行和列的index都是从0开始

3、POI读取Excel有两种格式一个是HSSF,另一个是XSSF。 HSSF和XSSF的区别如下: 
HSSF is the POI Project's pure Java implementation of the Excel '97(-2007) file format. 
XSSF is the POI Project's pure Java implementation of the Excel 2007 OOXML (.xlsx) file format. 
即:HSSF适用2007以前的版本,XSSF适用2007版本及其以上的。

下面是用NPOI读写Excel的例子:ExcelHelper封装的功能主要是把DataTable中数据写入到Excel中,或者是从Excel读取数据到一个DataTable中。

ExcelHelper类:

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using NPOI.HSSF.UserModel;
using System.IO;
using System.Data;namespace NetUtilityLib
{public class ExcelHelper : IDisposable{private string fileName = null; //文件名private IWorkbook workbook = null;private FileStream fs = null;private bool disposed;public ExcelHelper(string fileName){this.fileName = fileName;disposed = false;}/// <summary>/// 将DataTable数据导入到excel中/// </summary>/// <param name="data">要导入的数据</param>/// <param name="isColumnWritten">DataTable的列名是否要导入</param>/// <param name="sheetName">要导入的excel的sheet的名称</param>/// <returns>导入数据行数(包含列名那一行)</returns>public int DataTableToExcel(DataTable data, string sheetName, bool isColumnWritten){int i = 0;int j = 0;int count = 0;ISheet sheet = null;fs = new FileStream(fileName, FileMode.OpenOrCreate, FileAccess.ReadWrite);if (fileName.IndexOf(".xlsx") > 0) // 2007版本workbook = new XSSFWorkbook();else if (fileName.IndexOf(".xls") > 0) // 2003版本workbook = new HSSFWorkbook();try{if (workbook != null){sheet = workbook.CreateSheet(sheetName);}else{return -1;}if (isColumnWritten == true) //写入DataTable的列名
                {IRow row = sheet.CreateRow(0);for (j = 0; j < data.Columns.Count; ++j){row.CreateCell(j).SetCellValue(data.Columns[j].ColumnName);}count = 1;}else{count = 0;}for (i = 0; i < data.Rows.Count; ++i){IRow row = sheet.CreateRow(count);for (j = 0; j < data.Columns.Count; ++j){row.CreateCell(j).SetCellValue(data.Rows[i][j].ToString());}++count;}workbook.Write(fs); //写入到excelreturn count;}catch (Exception ex){Console.WriteLine("Exception: " + ex.Message);return -1;}}/// <summary>/// 将excel中的数据导入到DataTable中/// </summary>/// <param name="sheetName">excel工作薄sheet的名称</param>/// <param name="isFirstRowColumn">第一行是否是DataTable的列名</param>/// <returns>返回的DataTable</returns>public DataTable ExcelToDataTable(string sheetName, bool isFirstRowColumn){ISheet sheet = null;DataTable data = new DataTable();int startRow = 0;try{fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);if (fileName.IndexOf(".xlsx") > 0) // 2007版本workbook = new XSSFWorkbook(fs);else if (fileName.IndexOf(".xls") > 0) // 2003版本workbook = new HSSFWorkbook(fs);if (sheetName != null){sheet = workbook.GetSheet(sheetName);if (sheet == null) //如果没有找到指定的sheetName对应的sheet,则尝试获取第一个sheet
                    {sheet = workbook.GetSheetAt(0);}}else{sheet = workbook.GetSheetAt(0);}if (sheet != null){IRow firstRow = sheet.GetRow(0);int cellCount = firstRow.LastCellNum; //一行最后一个cell的编号 即总的列数if (isFirstRowColumn){for (int i = firstRow.FirstCellNum; i < cellCount; ++i){ICell cell = firstRow.GetCell(i);if (cell != null){string cellValue = cell.StringCellValue;if (cellValue != null){DataColumn column = new DataColumn(cellValue);data.Columns.Add(column);}}}startRow = sheet.FirstRowNum + 1;}else{startRow = sheet.FirstRowNum;}//最后一列的标号int rowCount = sheet.LastRowNum;for (int i = startRow; i <= rowCount; ++i){IRow row = sheet.GetRow(i);if (row == null) continue; //没有数据的行默认是null       
                        DataRow dataRow = data.NewRow();for (int j = row.FirstCellNum; j < cellCount; ++j){if (row.GetCell(j) != null) //同理,没有数据的单元格都默认是nulldataRow[j] = row.GetCell(j).ToString();}data.Rows.Add(dataRow);}}return data;}catch (Exception ex){Console.WriteLine("Exception: " + ex.Message);return null;}}public void Dispose(){Dispose(true);GC.SuppressFinalize(this);}protected virtual void Dispose(bool disposing){if (!this.disposed){if (disposing){if (fs != null)fs.Close();}fs = null;disposed = true;}}}
}
复制代码

测试代码:

 View Code

签于这篇文章阅读量较高,更新一下我使用Aspose.Cells的另一个版本:

PS:Aspose是要收费的

复制代码
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using Aspose.Cells;namespace NetUtilityLib
{public static class ExcelHelper{public static int DataTableToExcel(DataTable data, string fileName, string sheetName, bool isColumnNameWritten){int num = -1;try{Workbook workBook;Worksheet worksheet = null;if (File.Exists(fileName))workBook = new Workbook(fileName);elseworkBook = new Workbook();if (sheetName == null){if (workBook.Worksheets.Count > 0){worksheet = workBook.Worksheets[0];}else{sheetName = "Sheet1";workBook.Worksheets.RemoveAt(sheetName);worksheet = workBook.Worksheets.Add(sheetName);}}if (worksheet != null){worksheet.Cells.Clear();num = worksheet.Cells.ImportDataTable(data, isColumnNameWritten, 0, 0, false);workBook.Save(fileName);}}catch (Exception ex){Console.WriteLine(ex.Message);}return num;}public static void AddOneRowToExcel(DataRow dataRow, string fileName, string sheetName){try{Workbook workBook;if (File.Exists(fileName))workBook = new Workbook(fileName);elseworkBook = new Workbook();Worksheet worksheet=null;if (sheetName == null){worksheet = workBook.Worksheets[0];}else{worksheet = workBook.Worksheets[sheetName];}if (worksheet != null){worksheet.Cells.ImportDataRow(dataRow, worksheet.Cells.MaxDataRow + 1,0);//worksheet.Cells.ImportArray(dataArray, worksheet.Cells.MaxDataRow+1, 0, false);
                    workBook.Save(fileName);}}catch (Exception ex){Console.WriteLine(ex.Message);}}public static DataTable ExcelToDataTable(string fileName, string sheetName, bool isFirstRowColumnName){DataTable data = new DataTable();try{Workbook workbook = null;FileInfo fileInfo = new FileInfo(fileName);if (fileInfo.Extension.ToLower().Equals(".xlsx"))workbook = new Workbook(fileName, new LoadOptions(LoadFormat.Xlsx));else if (fileInfo.Extension.ToLower().Equals(".xls"))workbook = new Workbook(fileName, new LoadOptions(LoadFormat.Excel97To2003));if (workbook != null){Worksheet worksheet = null;if (sheetName != null){worksheet = workbook.Worksheets[sheetName];}else{worksheet = workbook.Worksheets[0];}if (worksheet != null){data = worksheet.Cells.ExportDataTable(0, 0, worksheet.Cells.MaxRow+1, worksheet.Cells.MaxColumn+1,isFirstRowColumnName);return data;}}else{return data;}}catch (Exception ex){Console.WriteLine(ex.Message);}return data;}}
}
复制代码

Excel相关DLL下载:NPOI-Lib.rar

1.NPOI下载地址:http://npoi.codeplex.com/releases/view/38113

2.NPOI学习系列教程推荐:http://www.cnblogs.com/tonyqus/archive/2009/04/12/1434209.html

参考:

http://www.cnblogs.com/Erik_Xu/archive/2012/06/08/2541957.html

http://www.cnblogs.com/linzheng/archive/2010/12/20/1912137.html

http://www.cnblogs.com/knowledgesea/archive/2012/11/16/2772547.html

作者:阿凡卢
出处:http://www.cnblogs.com/luxiaoxun/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
http://www.cnblogs.com/luxiaoxun/p/3374992.html

相关文章:

我的vim捣鼓之路

2016-06-13 更新 绑定独立博客到域名rebootcat.com 2016-06-12 更新文中的几个链接错误&#xff0c;google search报错 前言 从大二的时候就开始接触Linux了&#xff0c;从而也接触了vi,对的&#xff0c;当时对这些还不太了解&#xff0c;不知道还有个vim&#xff0c;真的觉得…

代码写对了还挂了?程序媛小姐姐从 LRU Cache 带你看面试的本质

来源 | 码农田小齐责编 | Carol 前言在讲这道题之前&#xff0c;我想先聊聊「技术面试究竟是在考什么」这个问题。技术面试究竟在考什么在人人都知道刷题的今天&#xff0c;面试官也都知道大家会刷题准备面试&#xff0c;代码大家都会写&#xff0c;那面试为什么还在考这些题&…

广船国际股份有限公司OA项目

2003年的老案例&#xff1a; 背景 广船国际股份有限公司是由原中国船舶工业总公司属下国有企业广州造船厂在1993年改组、在上海和香港同期上市的股份有限公司&#xff0c;公司享有自营进出口权。 广船国际于2002年3月通过评标后选定采用iOffice.net信息管理平台作为信息化建设…

注册表----修改Win7登录界面

在进行操作前&#xff0c;需要准备好背景图片。对背景图片的要求有三点&#xff1a; &#xff08;1&#xff09;图片必须是JPG格式&#xff1b; &#xff08;2&#xff09;必须将图片命名为backgroundDefault; &#xff08;3&#xff09;图片的体积必须小于256KB。 按下【WinR】…

定义自己的rm command

rm 是一个很危险的命令&#xff0c;别人一直说&#xff0c;我并没有在意&#xff0c;直到有一天一个不小心&#xff0c;忘记当前目录的位置&#xff0c;手贱的使用了rm命令&#xff0c;结果花了半天也没有把那些重要资料给恢复过来。所以还是有必要给自己定义一个不那么危险的r…

出任 Twitter 独立董事,AI 女神李飞飞的传奇人生

作者 | 年素清责编 | 伍杏玲出品 | 程序人生&#xff08;ID&#xff1a;coder_life&#xff09; 近日&#xff0c;Twitter宣布任命斯坦福大学计算机科学教授、前谷歌副总裁李飞飞为董事会独立董事。李飞飞本人表示&#xff1a;“推特是科技连接世界的一个重要平台&#xff0c;…

apache ab压力测试

2019独角兽企业重金招聘Python工程师标准>>> ab的原理&#xff1a;ab命令会创建多个并发访问线程&#xff0c;模拟多个访问者同时对摸一个URL地址进行访问。它的测试目标是基于URL的&#xff0c;因此它既可以用来测试apache的负载压力&#xff0c;也可以测试nginx、…

我的个人博客搭建记录

6/13更新 绑定个人博客到域名 rebootcat.com 前言 本篇博客旨在备忘&#xff0c;并记录了自己折腾了3,4天后顺利搭建自己的个人博客过程中碰到的一部分问题。 搭建个人独立博客有很多种方法&#xff0c;我暂时采用的是基于github Pages的免费博客&#xff0c;博客框架采用he…

oracle中创建触发器

从csdn上面看到一个如何创建触发器的问题&#xff0c;感觉自己很有必要保存学习&#xff0c;特写下来&#xff1a;条件&#xff1a;现有A、B两张表A&#xff1a; 工号 姓名 密码 性别 年龄 。。。B&#xff1a; 工号 姓名 密码当对A表中的“密码”字段进行修改时,B表中的“密码…

量子计算与AI“双拳”出击,他们锁定38种潜在抗疫药物

作者 | Just出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;医药研发行业有一个“三个十”的说法&#xff0c;即一种药物的发现需要投入十年以上的时间&#xff0c;花费十多亿美元&#xff0c;最后获得10%的成功率。也就是说&#xff0c;医药研发需要花费很长时间&am…

Android官方开发文档Training系列课程中文版:OpenGL绘图之应用投影与相机视图

原文地址&#xff1a;http://android.xsoftlab.net/training/graphics/opengl/projection.html##transform 在OpenGL ES环境中&#xff0c;投影相机View可以将所绘制的图形模拟成现实中所看到的物理性状。这种物理模拟是通过改变对象的数字坐标实现的&#xff1a; 投影 - 这基于…

Python分析101位《创造营2020》小姐姐,谁才是你心中的颜值担当?

来源 | CDA 数据分析师责编 | Carol Show me data&#xff0c;用数据说话。今天我们聊一聊《创造营2020》各个小姐姐&#xff0c;点击下方视频&#xff0c;先睹为快&#xff1a; 最近可以追的综艺真是太多了&#xff0c;特别是女团选秀节目。之前我们刚聊过《青春有你2》&…

体验Remix——安卓电脑

第一次听说Android-X86 以前玩唱吧的时候接触过PC上的安卓模拟器&#xff0c;不过这个只是一个软件&#xff0c;效果毕竟不好&#xff0c;想要把电脑变成安卓手机&#xff0c;还差远了。 然后&#xff0c;前段时间一直纠结要不要换个手机&#xff0c;我现在的华为小6已经跟我…

重置 microsoft visual studio窗口

“工具”->“导入导出设置”—>“重置所有设置”&#xff0c;在这个向导中可以重置编译环境的&#xff01;转载于:https://www.cnblogs.com/qiantuwuliang/archive/2011/05/31/2064825.html

排序算法总结之堆排序

一&#xff0c;堆排序介绍 堆是一个优先级队列&#xff0c;对于大顶堆而言&#xff0c;堆顶元素的权值最大。将 待排序的数组 建堆&#xff0c;然后不断地删除堆顶元素&#xff0c;就实现了排序。关于堆&#xff0c;参考&#xff1a;数据结构--堆的实现之深入分析 下面的堆排序…

Hessian通信案例(java)

个人博客&#xff1a; 戳我,戳我 前言 由于工作的原因&#xff0c;接触到了hessain,项目需要做hessain和xml之间的报文转换。但是对于hessian是个什么东西一头雾水。于是接下来的时间了解了hessain协议的序列化规则以及hessian协议进行通信的方式。这篇文章是在完成了这个模块…

VDI序曲二十一 APP-V 4.6 SP1服务器端部署

APP-V是微软应用程序虚拟化除RemoteApp以外非常棒的另一种应用程序虚拟化&#xff0c;此应用程序虚拟化是把搭开应用程序消耗的资源放在前端&#xff0c;应用程序虚拟化主要解决的还是软件兼容性问题和保护软件资产问题&#xff0c;同时让用户无需安装就可以绿色使用的手段&…

绝悟之后再超神,腾讯30篇论文入选AI顶会ACL

作者 | 马超责编 | Carol出品| AI科技大本营&#xff08;ID&#xff1a;rgznai100&#xff09;封图 | CSDN 付费下载于东方 IC近日&#xff0c;国际计算语言学协会年会ACL在官网(https://www.aclweb.org)公布了2020年度的论文收录名单&#xff0c;其中腾讯共有30篇论文入选&…

mac中用命令行运行mysql

1&#xff0c;安装mysql 在mysql的官方网站下载 mysql 5.5.23 http://www.mysql.com/downloads/mysql/&#xff0c;根据我的机器的配置情况选择了64bit版本。 2&#xff0c;命令行中启动mysql 安装的位置在/usr/local/mysql 于是做了一个别名&#xff1a; $alias mysql/usr/loc…

Hessian源码分析(java)

个人博客&#xff1a; 戳我&#xff0c;戳我 先扯一扯 前一篇博文Hessian通信案例(java)简单实现了Java版的Hessian客户端和服务端的通信&#xff0c;总体看来&#xff0c;实现起来比较简单&#xff0c;整个基于Hessian的远程调用过程也显得很方便。但是知其然还要知其所以然&…

必读!53个Python经典面试题详解

作者 | Chris翻译 | 苏本如&#xff0c;编辑 | 夕颜题图 | 视觉中国出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;本文列出53个Python面试问题&#xff0c;并且提供了答案&#xff0c;供数科学家和软件工程师们参考。不久前&#xff0c;我作为“数据科学家”开始担…

Microsoft Web 平台安装程序 (Web PI) Microsoft Web Platform Installer

Microsoft Web 平台安装程序 3.0 (Web PI) 是一款免费的工具&#xff0c;使用它可以获得 Microsoft Web 平台的最新组件&#xff08;包括 Internet Information Services (IIS)、SQL Server Express、.NET Framework 和 Visual Web Developer&#xff09;。Web PI 的内置Window…

Linux Shell 脚本限制ssh最大用户登录数

原创作品&#xff0c;允许转载&#xff0c;转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://dgd2010.blog.51cto.com/1539422/1670233 我撰写本文原来的意图是想把“复制SSH渠道”和"copy SSH Session"这样的功能从远程s…

hessiancpp编译和使用(C++版)

个人博客&#xff1a;戳我&#xff0c;戳我 许下的承诺 前两篇博客Hessian通信案例(java)和Hessian源码分析(java)介绍了Java版的hessian的使用以及源码分析。当时也说过打算写一下C版的hessian的使用和源码分析&#xff0c;现在就是兑现承诺的时候了。其实我项目中实际用到的…

美国AI博士一针见血:Python这样学最容易成为高手!

我见过市面上很多的 Python 讲解教程和书籍&#xff0c;他们大都这样讲 Python 的&#xff1a;先从 Python 的发展历史开始&#xff0c;介绍 Python 的基本语法规则&#xff0c;Python 的 list, dict, tuple 等数据结构&#xff0c;然后再介绍字符串处理和正则表达式&#xff0…

win7操作系统在哪显示隐藏文件夹

win7操作系统在哪显示隐藏文件夹 打开计算机--组织--文件夹和搜索选项--查看--把 “隐藏受保护的操作系统文件”前面的钩去掉&#xff0c;选中“显示隐藏的文件、文件夹和驱动器”--确定

ASP.NET MVC4中调用WEB API的四个方法

当今的软件开发中&#xff0c;设计软件的服务并将其通过网络对外发布&#xff0c;让各种客户端去使用服务已经是十分普遍的做法。就.NET而言&#xff0c;目前提供了Remoting,WebService和WCF服务&#xff0c;这都能开发出功能十分强大的服务。然而&#xff0c;越来越多的互联网…

使用docker制作hexo镜像

个人博客&#xff1a;戳我&#xff0c;戳我 背景 这段时间一直在折腾我的博客&#xff0c;由于之前出现过一次电脑硬盘完全挂掉的情况&#xff0c;为了避免重新搭建博客系统&#xff0c;一直打算搞一个方便点的环境&#xff0c;能进行多机迁移之类的。正好&#xff0c;Docker完…

3D目标检测深度学习方法数据预处理综述

作者 | 蒋天元来源 | 3D视觉工坊&#xff08;ID: QYong_2014&#xff09;这一篇的内容主要要讲一点在深度学习的3D目标检测网络中&#xff0c;我们都采用了哪些数据预处理的方法&#xff0c;主要讲两个方面的知识&#xff0c;第一个是representation&#xff0c;第二个数据预处…

NTLM协议认证

第一篇blog&#xff0c;发现这是个记录学习过程的好地方。从基础的开始吧。 NTLM&#xff1a; 基本知识telnet的一种验证身份方式&#xff0c;即Windows NT LAN Manager (NTLM)&#xff1b; NTLM 是为没有加入到域中的计算机&#xff08;如独立服务器和工作组&#xff09;提供的…