我的zip存档包含一堆纯文本文件。我想解析每个文本文件数据。这是我到目前为止所写的内容:
try {
final ZipFile zipFile = new ZipFile(chooser.getSelectedFile());
final Enumeration<? extends ZipEntry> entries = zipFile.entries();
ZipInputStream zipInput = null;
while (entries.hasMoreElements()) {
final ZipEntry zipEntry = entries.nextElement();
if (!zipEntry.isDirectory()) {
final String fileName = zipEntry.getName();
if (fileName.endsWith(".txt")) {
zipInput = new ZipInputStream(new FileInputStream(fileName));
final RandomAccessFile rf = new RandomAccessFile(fileName, "r");
String line;
while((line = rf.readLine()) != null) {
System.out.println(line);
}
rf.close();
zipInput.closeEntry();
}
}
}
zipFile.close();
}
catch (final IOException ioe) {
System.err.println("Unhandled exception:");
ioe.printStackTrace();
return;
}
我是否需要RandomAccessFile才能执行此操作?我失去了我拥有ZipInputStream的地步。
答案 0 :(得分:38)
不,您不需要RandomAccessFile
。首先获得一个InputStream
,其中包含此zip文件条目的数据:
InputStream input = zipFile.getInputStream(entry);
然后将其包装在InputStreamReader
(从二进制到文本解码)和BufferedReader
(一次读取一行)中:
BufferedReader br = new BufferedReader(new InputStreamReader(input, "UTF-8"));
然后正常读取它的行。像往常一样包裹try/finally
块中的所有相应位,以关闭所有资源。