c#使用NPOI导出Excel及往Excel里追加记录
最近在做一个打印发票的程序,要求保存打印记录,所以用到了NPOI往Excel里导入数据,但是遇到了一些问题没法解决,最后看了别人的Java程序后才明白。下面只是说明几个问题,而不是怎样使用NPOI
问题1:Invalid header signature; read 0x0000000000000000, expected 0xE11AB1A1E011CF
原因:通常的原因是读取的文件头信息不对,可能是类似于将txt文件的后缀名直接改成xls,或者由其他软件导出成的Excel。
意思是我们用FileStream fs=new FileStream("demo.xls");创建的Excel表,这其实是一个文本文件,所以不能用这种方式创建。
解决:
MemoryStream ms = new MemoryStream(); //创建内存流用于写入文件 IWorkbook workbook = new HSSFWorkbook(); //创建Excel工作部 ISheet sheet = workbook.CreateSheet("EquipBill");//创建工作表 IRow row = sheet.CreateRow(sheet.LastRowNum);//在工作表中添加一行 ICell cell = row.CreateCell(0);//创建单元格 cell1.SetCellValue("领用单位");//赋值 workbook.Write(ms);//将Excel写入流 ms.Flush(); ms.Position = 0; FileStream dumpFile = new FileStream(“demo.xls”, FileMode.Create, FileAccess.ReadWrite,FileShare.ReadWrite); ms.WriteTo(dumpFile);//将流写入文件
问题2:不能往Excel文件里追加记录
试了很多方法使用FileMode.Append会报错、利用sheet.LastRowNum+1创建一行再往里添加数据但是最后Excel里并没有显示
解决:
FileStream fs = new FileStream(“demo.xls”, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);//读取流 POIFSFileSystem ps=new POIFSFileSystem(fs);//需using NPOI.POIFS.FileSystem; IWorkbook workbook = new HSSFWorkbook(ps); ISheet sheet = workbook.GetSheetAt(0);//获取工作表 IRow row = sheet.GetRow(0); //得到表头 FileStream fout = new FileStream(“demo.xls”, FileMode.Open, FileAccess.Write, FileShare.ReadWrite);//写入流 row = sheet.CreateRow((sheet.LastRowNum + 1));//在工作表中添加一行 ICell cell1 = row.CreateCell(0); cell1.SetCellValue(“测试数据”);//赋值 fout.Flush(); workbook.Write(fout);//写入文件 workbook = null; fout.Close();
一看代码就明白了,先读取,再写入。为什么要得到表头,因为一个excel必须有字段列头即,字段列头,便于赋值
如果你遇到了我没遇到的问题,请分享给大家
转 :https://www.cnblogs.com/liuxiaobo93/p/3570654.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)