NPOI学习笔记
NPOI最简单的创建一个Excel,并且在指定单元格内填写一些数据
HSSFWorkbook workbook = new HSSFWorkbook(file);
ISheet sheet = workbook.CreateSheet("许嵩");
sheet.CreateRow().CreateCell().SetCellValue("我是牛逼村的");
sheet.GetRow().CreateCell().SetCellValue("蜀云泉真帅啊");
FileStream file = new FileStream("蜀云泉.xls",FileMode.Create);
workbook.Write(file);
file.Close();
不过这个没意思,大部分人在使用导出Excel的时候,不会傻傻的自己去创建一个新的Excel,使用模板才是最方便的方法。
模板的使用方法:

我在bin下面新建了两个文件夹,一个是模板,一个是结果。模板里面存放了一个excel模板,那做的是花里胡哨的,代码如下:
string fileDir = Environment.CurrentDirectory + "\\模板\\蜀云泉真帅.xls";
FileStream Dir = new FileStream(fileDir, FileMode.Open, FileAccess.Read);
HSSFWorkbook workbook = new HSSFWorkbook(Dir);
ISheet sheet = workbook.GetSheet("Sheet1"); sheet.GetRow().GetCell().SetCellValue("我");
sheet.GetRow().GetCell().SetCellValue("的");
sheet.GetRow().GetCell().SetCellValue("妈");
sheet.GetRow().GetCell().SetCellValue("呀");
sheet.GetRow().GetCell().SetCellValue("我");
sheet.GetRow().GetCell().SetCellValue("真");
sheet.GetRow().GetCell().SetCellValue("是");
sheet.GetRow().GetCell().SetCellValue("帅"); sheet.ForceFormulaRecalculation = true; //强制计算Excel中的公式 FileStream file = new FileStream(Environment.CurrentDirectory + $"\\结果\\蜀云泉真帅{DateTime.Now.ToString("D")}.xls", FileMode.Create);
workbook.Write(file);
file.Close();
如此,如此。这里还需要说明的一个事情是,我在测试这个案例的时候,一直报错,说我的对象应用未引用到实例什么的,但是我检查感觉没问题啊,最后发现我必须在模板里面需要填写的单元格随便填上一些东西,比如0或者其它乱七八糟的字符。NPOI才相信我这一列是存在的。。。。
以上就是NPOI写内容进Excel的一些操作。但是有的时候外面还需要去读取Excel里面的内容。NPOI读取Excel内容代码如下所示:
//读取excel
public List<string> ExcelToDataTable(string filePath, bool isColumnName)
{
//DataTable dataTable = null;
List<string> list = new List<string>();
FileStream fs = null;
IWorkbook workbook = null;
ISheet sheet = null;
ICell cell = null;
string result=null;
try
{
using (fs = File.OpenRead(filePath))
{
// 2007版本
if (filePath.IndexOf(".xlsx") > )
workbook = new XSSFWorkbook(fs);
// 2003版本
else if (filePath.IndexOf(".xls") > )
workbook = new HSSFWorkbook(fs); if (workbook != null)
{
sheet = workbook.GetSheetAt();//读取第一个sheet,当然也可以循环读取每个sheet
//dataTable = new DataTable();
if (sheet != null)
{
int rowCount = sheet.LastRowNum;//总行数
if (rowCount > )
{
IRow firstRow = sheet.GetRow();//第3行
int cellCount = firstRow.LastCellNum;//列数 //构建datatable的列
if (isColumnName)
{
for (int i = firstRow.FirstCellNum; i < cellCount; i++)
{
cell = firstRow.GetCell(i);
if (cell != null)
{
result = cell.Row.Cells[i].ToString();
list.Add(result); }
}
}
else
{
//for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
//{
// column = new DataColumn("column" + (i + 1));
// dataTable.Columns.Add(column);
//}
} }
}
}
}
return list;
}
catch (Exception)
{
if (fs != null)
{
fs.Close();
}
return null;
}
}
基本代码就是这样的。
有的单元格的文字是有链接的,读取文字和链接使用的方法如下
string name = Row.GetCell().Row.Cells[].ToString();
string a = Row.GetCell().Row.Cells[].Hyperlink.Address;
NPOI学习笔记的更多相关文章
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
- 2014年暑假c#学习笔记目录
2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...
- JAVA GUI编程学习笔记目录
2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...
- seaJs学习笔记2 – seaJs组建库的使用
原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...
- CSS学习笔记
CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...
- HTML学习笔记
HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...
- DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记
今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...
随机推荐
- mybatis分页 -----PageHelper插件
对查询结果进行分页 一,使用limit进行分页 1.mybatis 的sql语句: <if test="page !=null and rows !=null"> li ...
- [转帖]关于hostnamectl 命令
作者:Linux运维 来源:CSDN 原文:https://blog.csdn.net/linuxnews/article/details/51112022 版权声明:本文为博主原创文章,转载请附上博 ...
- 【转帖】intel 2018年1 月2号爆出漏洞分析 知乎匿名用户
作者:匿名用户链接:https://www.zhihu.com/question/265012502/answer/288407097来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载 ...
- CSS 选择器继承和层叠
CSS选择器及其继承特性.层叠特性1.基本选择器 标记 id class 这个就不再作介绍了 2.复合选择器 交集 交集选择器由两个选择器直接连接构成,其结果是选中二者各自元素范围的交集 其 ...
- hive分区表
分区表创建 row format delimited fields terminated by ',';指明以逗号作为分隔符 依靠插入表创建分区表 从表sample_table选择 满足分区条件的 ...
- python删除数组元素导致跳过元素
复现的情况大概可以写成这样 abc = [1, 2, 2, 3, 4] print abc for index, i in enumerate(abc): if i == 2: del abc[ind ...
- ThinkPHP 框架出现安全隐患 ,导致网站被持续攻击一周
导读 据 ZDNET 报道,有超过 45000 个中国网站由于使用 ThinkPHP 框架受到了攻击. 这些攻击针对的是使用 ThinkPHP 构建的网站,ThinkPHP 是一个中国的 PHP 框架 ...
- 一个本科学生对Linux的认知
我是一名大三的普通一本大学的软件工程的一名学生,学校开设了一些关于系统开发的课程,纸上得来终觉浅,学校的课程课时较短,想要在56个课时之内学会一些公司需要的技能,无疑是纸上谈兵,一门语言的学习,需要的 ...
- [IOI2018]狼人——kruskal重构树+可持久化线段树
题目链接: IOI2018werewolf 题目大意:给出一张$n$个点$m$条边的无向图,点和边可重复经过,一个狼人初始为人形,有$q$次询问,每次询问要求人形态只能处于编号不小于$L$的点,狼形态 ...
- 图之强连通、强连通图、强连通分量 Tarjan算法
原文地址:https://blog.csdn.net/qq_16234613/article/details/77431043 一.解释 在有向图G中,如果两个顶点间至少存在一条互相可达路径,称两个顶 ...