使用Apache poi将excel转换为XSSFWorkbook需要很长时间 - java

我正在尝试将excel文件转换为XSSFWorkbook,我大约有7000行和大约145列。在下面的我的代码中,将Excel文件转换为第2行的XSSFWorkbook大约需要15分钟:-

InputStream fs = new FileInputStream(filename);   // (1)
XSSFWorkbook wb = new XSSFWorkbook(fs);           // (2)
XSSFSheet sheet = wb.getSheetAt(0); 

与其在XFFSWorkbook中添加7000行,不如在转换第2行时在XFFSWorkbook中添加30行?

如果没有,如何减少将excel转换为XSSFWorkbook所需的时间?

参考方案

*.xlsx文件是ZIP存档,在具有不同Excel文件的目录结构中包含XML的数据。

例如有

/xl/workbook.xml描述基本的工作簿结构,
/xl/worksheets/sheet1.xml/xl/worksheets/sheet2.xml,...
具有表数据的/xl/worksheets/sheetN.xml-这是行
而不是直接存储单元格中的所有数据
那里。同样,单元格样式不直接存储在此处。 -,
/xl/styles.xml包含单元格样式,
/xl/sharedStrings.xml包含单元格中所有字符串内容
所有工作表。这是为了避免多次存储同一字符串
如果此字符串在单元格中多次使用,则返回。

因此,如果您想读取*.xlsx ZIP存档,则需要解压缩ZIP存档,然后至少解析上述四个XML文件以获取XSSFWorkbook的数据。这是apache poiXSSFWorkbook wb = new XSSFWorkbook(fileinputstream);期间所做的。

因此,如果您确实需要XSSFWorkbook作为结果,则无法解决此过程。而且,如果您不怀疑已经编写了显式延迟例程,那么将不可能减少此过程的时间。

您只读取少于存储在工作表中的行的方法可能节省时间。但是,结果将是一个apache poi,其中包含所有样式和所有字符串内容,但仅包含与这些样式和字符串数据相关的某些工作表数据。因此,这将导致部分损坏的XSSFWorkbook。这就是为什么没人真正考虑过这种方法的原因。

仅当要求仅从其中一个XSSFWorkbook中读取原始无格式的数据而不创建/xl/worksheets/sheetN.xml时,才需要解压缩XSSFWorkbook存档,然后仅解析所需的ZIP/xl/worksheets/sheetN.xml从中获取单元格的字符串内容。比上述整个过程所需的时间更少。

JAVA:字节码和二进制有什么区别? - java

java字节代码(已编译的语言,也称为目标代码)与机器代码(当前计算机的本机代码)之间有什么区别?我读过一些书,他们将字节码称为二进制指令,但我不知道为什么。 参考方案 字节码是独立于平台的,在Windows中运行的编译器编译的字节码仍将在linux / unix / mac中运行。机器代码是特定于平台的,如果在Windows x86中编译,则它将仅在Win…

java:继承 - java

有哪些替代继承的方法? java大神给出的解决方案 有效的Java:偏重于继承而不是继承。 (这实际上也来自“四人帮”)。他提出的理由是,如果扩展类未明确设计为继承,则继承会引起很多不正常的副作用。例如,对super.someMethod()的任何调用都可以引导您通过未知代码的意外路径。取而代之的是,持有对本来应该扩展的类的引用,然后委托给它。这是与Eric…

Java:BigInteger,如何通过OutputStream编写它 - java

我想将BigInteger写入文件。做这个的最好方式是什么。当然,我想从输入流中读取(使用程序,而不是人工)。我必须使用ObjectOutputStream还是有更好的方法?目的是使用尽可能少的字节。谢谢马丁 参考方案 Java序列化(ObjectOutputStream / ObjectInputStream)是将对象序列化为八位字节序列的一种通用方法。但…

Java DefaultSslContextFactory密钥库动态更新 - java

我有一个使用org.restlet.engine.ssl.DefaultSslContextFactory的现有应用程序和一个在服务器启动时加载的密钥库文件。我有另一个应用程序,该应用程序创建必须添加的证书服务器运行时动态地更新到密钥库文件。为此,我在代码中创建了证书和私钥,然后将其写入到目录。该目录由bash脚本监视,该脚本检查是否有新文件,如果出现,它将…

Java-如何将此字符串转换为日期? - java

我从服务器收到此消息,我不明白T和Z的含义,2012-08-24T09:59:59Z将此字符串转换为Date对象的正确SimpleDateFormat模式是什么? java大神给出的解决方案 这是ISO 8601标准。您可以使用SimpleDateFormat simpleFormat = new SimpleDateFormat("yyyy-MM…