• 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必须有字段列头即,字段列头,便于赋值 

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

  • 相关阅读:
    常用辅助类(ContDownLatch、CyclicBarrier、Semaphore)
    Redis
    SpringBoot
    微服务概述
    数据库 子查询和分页查询
    数据库基础语句,聚合函数,练习
    数据库基础知识

    for循环的类型以及while循环
    C#编程循环练习
  • 原文地址:https://www.cnblogs.com/liuxiaobo93/p/3570654.html
Copyright © 2020-2023  润新知