标签:blog http os ar 使用 for sp strong 文件
转载请注明出处 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(); }
第二步
在读入之后,操作HSSFWorkbook这个类就和第一篇教程里一样了。
必须要遵循的一个规则是,如果你要编辑的行和单元格,原本没有值,或者从未创建过的,就必须先创建。
如:
我要使用第二行第一列的单元格,在上一篇教程中并未对这个位置进行创建,那么必须先创建。
//在第二行创建行 IRow row = sheet.CreateRow(1); //在第二行的第一列创建单元格 ICell cell = row.CreateCell(0);
之后这个cell才能被使用。
在上一篇教程中,我们已经对该文件的第一行第一列的这个位置创建过单元格,并且赋值,所以可以直接使用,采用下面的方式。
//获取第一行 IRow row = sheet.GetRow(0); //在第一行获取第一列单元格 ICell cell = row.GetCell(0);
上面两种写法也可以简写成如下的方式
//创建第二行,第一列 ICell cell = sheet.CreateRow(1).CreateCell(0); //获取第一行,第一列 ICell cell = sheet.GetRow(0).GetCell(0);
然后使用cell.SetCellValue()函数对其赋值即完成编辑。
当然,赋值语句也可以和上述语句并作一行书写。例如
sheet.GetRow(0).GetCell(0).SetCellValue("编辑的值");
第三步
编辑完之后需要保存
using (FileStream fileStream = File.Open("d:\\excel.xls", FileMode.OpenOrCreate, FileAccess.ReadWrite)) { wk.Write(fileStream); fileStream.Close(); }
这样就完成了读入已有文件,编辑,保存。
标签:blog http os ar 使用 for sp strong 文件
原文地址:http://www.cnblogs.com/alex-13/p/4067269.html