c#使用NPOI导出Excel及往Excel里追加记录

作者: gaohailin 分类: 编程技术 发布时间: 2019-12-19 07:10

最近在做一个打印发票的程序,要求保存打印记录,所以用到了NPOI往Excel里导入数据,但是遇到了一些问题没法解决,最后看了别人的Java程序后才明白。下面只是说明几个问题,而不是怎样使用NPOI

问题1:Invalid header signature; read 0x0000000000000000, expected 0xE11AB1A1E011CF

原因:通常的原因是读取的文件头信息不对,可能是类似于将txt文件的后缀名直接改成xls,或者由其他软件导出成的Excel。

意思是我们用FileStream fs=new FileStream(“demo.xls”);创建的Excel表,这其实是一个文本文件,所以不能用这种方式创建。

解决:

问题2:不能往Excel文件里追加记录

试了很多方法使用FileMode.Append会报错、利用sheet.LastRowNum+1创建一行再往里添加数据但是最后Excel里并没有显示

解决:

一看代码就明白了,先读取,再写入。为什么要得到表头,因为一个excel必须有字段列头即,字段列头,便于赋值

如果你遇到了我没遇到的问题,请分享给大家

如果觉得我的文章对您有用,请随意赞赏。您的支持将鼓励我继续创作!

发表评论

电子邮件地址不会被公开。 必填项已用*标注