NPOI插件的弊端
刚来公司的时候公司软件导入导出操作都使用微软的office组件来实现,大家应该都知道这个组件有很大的弊端,就是运行主机上面必须安装office组件才可进行使用,不然无法进行导入导出操作,之前公司软件部门给的做法就是直接让客户安装Office就可以解决。
我接手后知道这个弊端,将插件进行了替换,使用网上比较流行的NPOI插件,基本上很少出现关于软件导入导出数据的反馈。但由于之前的软件需求基本都是少量数据的导入导出,NPOI都可以满足,现在新需求要求导入导出超过40w行的数据,NPOI插件就暴露出来弊端,在数据少的时候使用.xlsx的XFFSWorkbook类就可以实现,但是数据量超过某一个阀值,XFFSWorkbook就出现了异常,爆出内存溢出的消息,而且声明和访问时速度特别慢,感觉是组件内部在处理大数据文件时存在问题。
在网上查找发现NPOI对于大数据的处理有一个SXSSFWorkbook,它是NPOI专门来处理大数据文件的,我在使用过程中,当写入时,没问题可以使用,但是效率方面很差。可是在读取时,根本无法使用,因为它在使用过程中必须声明XFFWorkbook才可以,可是声明它的话就会遇到内存溢出问题。网上还有说直接使用
//声明处理.xlsx文件的方法(小文件)IWorkbook workbook=new XSSFWorkbook();//声明处理.xlsx文件的方法(大文件)IWorkbook workbook=new XSSFWorkbook();IWorkbook wb=new SXSSFWorkbook(workbook);
ExcelDataReader插件
在处理读取.xlsx文件时,在nuget中发现了ExcelDataReader插件,在做了demo后,对于40w行的读取很方便,而且速度特别快。推荐大家使用。
FileStream fs = null; IExcelDataReader excelReader = null; try { fs = new FileStream(fileName, FileMode.Open, FileAccess.Read); excelReader = ExcelReaderFactory.CreateOpen
插件下载地址:
https://www.nuget.org/packages/ExcelDataReader/3.0.0
原文转载:http://www.shaoqun.com/a/704738.html
pat:https://www.ikjzd.com/w/1079
芒果店长:https://www.ikjzd.com/w/1533
NPOI插件的弊端刚来公司的时候公司软件导入导出操作都使用微软的office组件来实现,大家应该都知道这个组件有很大的弊端,就是运行主机上面必须安装office组件才可进行使用,不然无法进行导入导出操作,之前公司软件部门给的做法就是直接让客户安装Office就可以解决。我接手后知道这个弊端,将插件进行了替换,使用网上比较流行的NPOI插件,基本上很少出现关于软件导入导出数据的反馈。但由于之前的软件
折扣网:https://www.ikjzd.com/w/74
vat:https://www.ikjzd.com/w/109
picitup:https://www.ikjzd.com/w/446
嫁给二手男之后才得知自己成了后妈:http://lady.shaoqun.com/m/a/272311.html
老公出轨 骂刚出生的女儿是"烧钱罐:http://lady.shaoqun.com/a/272256.html
亚马逊如何发货最省钱?卖家必知的几种物流发货模式!:https://www.ikjzd.com/home/21846
没有评论:
发表评论