我正在编写一个工具来在 DOCX 文件中进行一些次要的文本替换,这是一种压缩格式。我的方法是使用 ZipEntry
将 ZipOutputStream
内容从原始文件中的条目复制到修改后的文件中。对于大多数 DOCX 文件,这很有效,但有时我会遇到 ZipException
s,因为我编写的内容与 ZipEntry
中包含的元信息之间存在差异(通常是压缩大小的差异)。
这是我用来复制内容的代码。为简洁起见,我去掉了错误处理和文档处理;到目前为止,我还没有遇到文档输入问题。
ZipFile original = new ZipFile(INPUT_FILENAME);
ZipOutputStream outputStream = new ZipOutputStream(new FileOutputStream(OUTPUT_FILE));
Enumeration entries = original.entries();
byte[] buffer = new byte[512];
while (entries.hasMoreElements()) {
ZipEntry entry = (ZipEntry)entries.nextElement();
if ("word/document.xml".equalsIgnoreCase(entry.getName())) {
//perform special processing
}
else{
outputStream.putNextEntry(entry);
InputStream in = original.getInputStream(entry);
while (0 < in.available()){
int read = in.read(buffer);
outputStream.write(buffer,0,read);
}
in.close();
}
outputStream.closeEntry();
}
outputStream.close();
将
ZipEntry
对象从一个 ZipFile
直接复制到另一个的正确或惯用方法是什么? 最佳答案
我找到了一种避免错误的解决方法。通过创建一个只有名称字段集的新 ZipEntry
,我可以毫无问题地复制内容。
ZipFile original = new ZipFile(INPUT_FILENAME);
ZipOutputStream outputStream = new ZipOutputStream(new FileOutputStream(OUTPUT_FILE));
Enumeration entries = original.entries();
byte[] buffer = new byte[512];
while (entries.hasMoreElements()) {
ZipEntry entry = (ZipEntry)entries.nextElement();
if ("word/document.xml".equalsIgnoreCase(entry.getName())) {
//perform special processing
}
else{
// create a new empty ZipEntry
ZipEntry newEntry = new ZipEntry(entry.getName());
// outputStream.putNextEntry(entry);
outputStream.putNextEntry(newEntry);
InputStream in = original.getInputStream(entry);
while (0 < in.available()){
int read = in.read(buffer);
if (read > 0) {
outputStream.write(buffer,0,read);
}
}
in.close();
}
outputStream.closeEntry();
}
outputStream.close();
但是,此方法会丢失原始
ZipEntry
字段中存储的任何元信息(例如:注释、额外)。 API 文档不清楚这是否重要。关于java - 将 ZipEntry 复制到新 ZipFile 的惯用方法是什么?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11766741/