質問

2007年のMS ExcelでXMLファイルの1つを変更しようとしています。このため、XLSXファイルはJavaのZipinputStreamを使用して解凍され、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

zipinputStreamは、JPEGファイルがコピーされるとすぐに閉じられます。 (EntryEofとReacheof変数は両方とも真実になり、Entryは画像をコピーした後にnullです)。

誰かが同様の問題に直面しましたか?ファイルをコピーした後にもReachEOFが真実になるのはバグですか?

ミッドハン。

役に立ちましたか?

解決

これは、からの画像のデータを読んだためです zis の代わりに zis.getInputStream(entry).

コピーループの後、すべてのデータ zis 読まれたので、EOFを取得します。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top