我们正在尝试在2007 MS Excel中修改XML文件之一。为此,使用Java的ZipinputStream解开XLSX文件,然后使用ZipOutputStream复制到新的ZIP文件。代码片段如下:

        FileInputStream fis = new FileInputStream("C:\\_132139TRD-GDR_Conversion.xlsx");
        ZipInputStream zis = new ZipInputStream(new BufferedInputStream(fis));

        FileOutputStream fos =  new FileOutputStream("C:\\_132139TRD-GDR_Conversion123.xlsx");
        ZipOutputStream zos = new ZipOutputStream(new BufferedOutputStream(fos));

        while ((entry = zis.getNextEntry()) != null) {

            System.out.println("Processing Entry : " + entry.getName());
            System.out.println("Processing Entry Size : " + entry.getSize());
            System.out.println("Entry Available : " + zis.available());

        if(entry.getName().equals(ZIP_ENTRY_WOOKBOOK_XML)){
          //Process XML
        }

        ZipEntry ze = new ZipEntry(entry.getName());
            zos.putNextEntry(ze);
            if(entry.getName().equals(ZIP_ENTRY_WOOKBOOK_XML)){
                    zos.write(XML.getBytes());
            }else{
                ByteArrayOutputStream stream = new ByteArrayOutputStream();
                while ((count = zis.read(data, 0, BUFFER)) != -1) {
                    stream.write(data, 0, count);
                }
                tempBuffer = stream.toByteArray();
                zos.write(tempBuffer);
            }
            zos.closeEntry();               
        }
        zos.close();
        fos.close();
        zis.close();
        fis.close();

在此片段中,我们遇到JPEG文件后,“ entry = zis.getNextentry()”返回null。我们无法阅读下一个Zipentry,这会导致不完整的Excel。示例Excel文件的输出如下:

Start Date Mon Dec 06 15:33:33 IST 2010
Processing Entry : xl/media/Logo2005_JPM_A_Black_170x50.jpeg
Processing Entry Size : -1
Entry Available : 1
End Date Mon Dec 06 15:34:58 IST 2010

复制JPEG文件后,ZipInputStream立即关闭。 (在复制图像后,输入和触及变量均为真实,并且输入为null)。

有人面临类似问题吗?复制文件后,到达的错误是否也变为true?

米德猎人。

有帮助吗?

解决方案

这是因为您从 zis 而不是来自 zis.getInputStream(entry).

复制循环后,所有数据来自 zis 将被阅读,因此您会得到EOF。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top