NPOI 2.0 教程(二):编辑既存的EXCEL文件
转载请注明出处 http://blog.csdn.net/fujie724
上一篇中讲了用NPOI创建新EXCEL文件的基本方法,但有时候我们需要的是对一个已有的EXCEL文件进行编辑修改。那么用NPOI该怎么做呢?
请接着学习
在这一篇里,我们读入上一篇教程中生成的EXCEL,然后以其做为模版,修改之后保存为另一份EXCEL
第一步
- //上一篇教程中生成的文件
- string tempPath = "d:\\excel.xls";
- HSSFWorkbook wk = null;
- using (FileStream fs = File.Open(tempPath, FileMode.Open,
- FileAccess.Read, FileShare.ReadWrite))
- {
- //把xls文件读入workbook变量里,之后就可以关闭了
- wk = new HSSFWorkbook(fs);
- fs.Close();
- }
//上一篇教程中生成的文件
string tempPath = "d:\\excel.xls";
HSSFWorkbook wk = null;
using (FileStream fs = File.Open(tempPath, FileMode.Open,
FileAccess.Read, FileShare.ReadWrite))
{
//把xls文件读入workbook变量里,之后就可以关闭了
wk = new HSSFWorkbook(fs);
fs.Close();
}
第二步
在读入之后,操作HSSFWorkbook这个类就和第一篇教程里一样了。
必须要遵循的一个规则是,如果你要编辑的行和单元格,原本没有值,或者从未创建过的,就必须先创建。
如:
我要使用第二行第一列的单元格,在上一篇教程中并未对这个位置进行创建,那么必须先创建。
- //在第二行创建行
- IRow row = sheet.CreateRow(1);
- //在第二行的第一列创建单元格
- ICell cell = row.CreateCell(0);
//在第二行创建行
IRow row = sheet.CreateRow(1);
//在第二行的第一列创建单元格
ICell cell = row.CreateCell(0);
之后这个cell才能被使用。
- 那么如果我不创建,直接使用会怎么样呢?
- 答:sheet.GetRow(1)取回来的值为null,在null上再使用GetCell(0)就会报空对象的错误。
在上一篇教程中,我们已经对该文件的第一行第一列的这个位置创建过单元格,并且赋值,所以可以直接使用,采用下面的方式。
- //获取第一行
- IRow row = sheet.GetRow(0);
- //在第一行获取第一列单元格
- ICell cell = row.GetCell(0);
//获取第一行
IRow row = sheet.GetRow(0);
//在第一行获取第一列单元格
ICell cell = row.GetCell(0);
上面两种写法也可以简写成如下的方式
- //创建第二行,第一列
- ICell cell = sheet.CreateRow(1).CreateCell(0);
- //获取第一行,第一列
- ICell cell = sheet.GetRow(0).GetCell(0);
//创建第二行,第一列
ICell cell = sheet.CreateRow(1).CreateCell(0); //获取第一行,第一列
ICell cell = sheet.GetRow(0).GetCell(0);
然后使用cell.SetCellValue()函数对其赋值即完成编辑。
当然,赋值语句也可以和上述语句并作一行书写。例如
- sheet.GetRow(0).GetCell(0).SetCellValue("编辑的值");
sheet.GetRow(0).GetCell(0).SetCellValue("编辑的值");
第三步
编辑完之后需要保存
- using (FileStream fileStream = File.Open("d:\\excel.xls",
- FileMode.OpenOrCreate, FileAccess.ReadWrite))
- {
- wk.Write(fileStream);
- fileStream.Close();
- }
using (FileStream fileStream = File.Open("d:\\excel.xls",
FileMode.OpenOrCreate, FileAccess.ReadWrite))
{
wk.Write(fileStream);
fileStream.Close();
}
这样就完成了读入已有文件,编辑,保存。
NPOI 2.0 教程(二):编辑既存的EXCEL文件的更多相关文章
- 【Java/JDBC】借助ResultSetMetaData,从数据库表中抽取字段信息存成Excel文件
本例工程下载:https://files.cnblogs.com/files/xiandedanteng/FindNotnullColumns20191102-3.rar 工作中曾有个为42张表建立测 ...
- HTML 表单 存为EXCEL文件时 中文显示乱码
在做宣传品发放系统时,需求要把数据库查询的记录生成表单并转存excel文件. 在转存的EXCEL文件中文显示乱码,表格和其他字符正常,检查后发现是创建EXCEL文件打开模式不对 之前: myfile ...
- NPOI 2.0 读取、编辑、保存Excel文件
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.I ...
- NPOI 2.0 教程
NPOI2.0帮助官方地址 目录 1. 前言 1.1 NPOI 2.0与NPOI 1.x的区别 1.2 NPOI 2.0模块简介 1.3 自动识别并打开Excel 2003和Excel 2007文件 ...
- centos6.5安装tomcat7.0教程(二)
阅读之前对基本命不熟悉的话, 可以先安装另一文章: http://www.cnblogs.com/duenboa/articles/6665159.html把基本的命令记一下.后面的文章就不重复演示了 ...
- discuz X2.0教程]教你快速了解Discuz!程序文件功能,修改文件从此不用再求人
x3.x数据字典 http://faq.comsenz.com/library/database/x3/x3_index.htm 先从根目录开始,根目录文件一般都是入口,即执行具体功能的代码一般不在这 ...
- PHP导出excel文件,第二步先实现自写二维数组加入模板excel文件后导出
今天主要研究数据加入EXCEL并导出的问题,先不从数据库提取数据导出,自己先写一个二维数组,然后遍历二维数组写入excel模板中导出,首先根据模板excel的内容书写对应的二维数组 $arr=arra ...
- RxJava2.0教程
尝试在新的项目中,引用一些流行的优秀的开源框架,在简书上偶然发现一篇很棒的写RxJava 2.0的帖子,个人认为非常适合Android开发者,你可以先知道怎么使用,然后再弄清楚里面做了哪些事情,例如可 ...
- NPOI 2.0 创建Excel文件
如果只是简单的处理的话,只需要引用下载压缩包里的 NPOI.dll (office 2003)或 NPOI.OOXML.dll (office 2007) 文件而已. using System; us ...
随机推荐
- Python 学习笔记9
梦想和我只有一层纸的距离. 接着看Python类:http://www.pythondoc.com/pythontutorial3/classes.html
- Git Bash 简单操作
在Windows下使用Git Bash,用的是Linux命令,常用几个文件操作命令如下: Windows命令 Linux命令 意义 cd e:\xxx cd /e/xxx 切换到xxx目录 cd pw ...
- c#控制其他程序窗口位置
//调用Win32 API [System.Runtime.InteropServices.DllImportAttribute("user32.dll", EntryPoint ...
- URL匹配与req参数解析
通配URL*(可代表任何字符串) 例如: app.get('/test/*', function(req, res){ res.send(req.query.aa); }) '/test/*通配tes ...
- cocos2d-x 获得系统语言繁体
IosLocalUtil.h #ifndef __IOS_LOCALUTIL_H__ #define __IOS_LOCALUTIL_H__ class IosLocalUtil{ public: s ...
- 反编译app方法
如果你没有代码,那么可以反编译该app. 这里将用到2个工具,分别是dex2jar和jd-gui.你可以在这里下载目前为止的最新版本以及示例apk. 我们以工具包里的ContactManager.ap ...
- 常用的css
产品鼠标经过加边框效果 .productsCol:hover { box-shadow: 0 0 0 3px #333333 inset; transition: all 0.2s ease 0s; ...
- 一个Cmake的例子
命令查询列表:http://www.cmake.org/cmake/help/v3.2/manual/cmake-commands.7.html # # Official dependency num ...
- 认识ASP.NET MVC的5种AuthorizationFilter
在总体介绍了筛选器及其提供机制(<深入探讨ASP.NET MVC的筛选器>)之后,我们按照执行的先后顺序对四种不同的筛选器进行单独介绍,首先来介绍最先执行的AuthorizationFil ...
- php中的PHP_EOL换行符
看手册时发现PHP_EOL这个变量,查了下资料,原来是相当于换行符 在unix系列用 \n 在windows系列用 \r\n 在mac用 \r PHP中可以用PHP_EOL来替代,以提高代码的源代 ...