[英]zip4j How to extract a directory
我需要使用 zip4j 从 zip 中提取一个目录。 我可以找到目录中的每个文件并将其解压缩。
如何列出目录中的文件?
或者,是否有将目录提取到路径的实用程序?
从 Zip4j 的ZipFile
,您可以获取此 zip 文件中所有文件头的列表。 然后你可以从这个文件头中检查这个“文件”是否是一个目录。 如果是,请提取它。
以下是仅从 zip 文件中提取目录的示例代码
import java.util.List;
import net.lingala.zip4j.core.ZipFile;
import net.lingala.zip4j.exception.ZipException;
import net.lingala.zip4j.model.FileHeader;
public class ExtractDirectory {
public static void main(String[] args) {
try {
ZipFile zipFile = new ZipFile("myZipWithDirectories.zip");
if (zipFile.isEncrypted()) {
zipFile.setPassword("test".toCharArray());
}
@SuppressWarnings("unchecked")
List<FileHeader> fileHeaders = zipFile.getFileHeaders();
for(FileHeader fileHeader : fileHeaders) {
if (fileHeader.isDirectory()) {
zipFile.extractFile(fileHeader, "anyValidPathToExtractTo");
}
//Alternatively, if you want to extract a directory by its name
//if (fileHeader.isDirectory() && fileHeader.getFileName().equals("myDirectoryName")) {
// zipFile.extractFile(fileHeader, "anyValidPathToExtractTo");
//}
}
} catch (ZipException e) {
e.printStackTrace();
}
}
}
在 zip4j 中,您应该能够利用myZipFile.getFileHeaders()
或zipFile.getFileHeader("TargetFolder");
函数提取目标文件夹。
//List<FileHeader> fHeaders = myZipFile.getFileHeaders(); for all file Header
FileHeader targetFileHeader = zipFile.getFileHeader("TargetFolder");
if (targetFileHeader.isDirectory()) {
File f = new File("anyGivenDirectory/" + targetFileHeader.getFileName());
f.mkdirs(); // mkdirs() is different from mkdir()
zipFile.extractFile(fileHeader, f.toString());
}
据我所知,另一个已知的好库: zt-zip 。 但我不确定它是否支持解密。
使用这个库 www.lingala.net/zip4j/
将此jar文件添加到应用程序的lib文件夹中。
像这样检查您的导入
导入 net.lingala.zip4j.core.ZipFile;
导入 net.lingala.zip4j.exception.ZipException;
导入 net.lingala.zip4j.model.FileHeader;
像这样使用下面的方法
unzip("/sdcard/file.zip","/sdcard/unzipFolder")
public static void unzip(String Filepath, String DestinationFolderPath) {
try {
ZipFile zipFile = new ZipFile(Filepath);
List fileHeaders = zipFile.getFileHeaders();
for(FileHeader fileHeader : fileHeaders) {
String fileName = fileHeader.getFileName();
if (fileName.contains("\\")) {
fileName=fileName.replace("\\","\\\\");
String[] Folders=fileName.split("\\\\");
StringBuilder newFilepath=new StringBuilder();
newFilepath.append(DestinationFolderPath);
for (int i=0;i< Folders.length-1;i++){
newFilepath.append(File.separator);
newFilepath.append(Folders[i]);
}
zipFile.extractFile(fileHeader, newFilepath.toString(),null,Folders[Folders.length-1]);
}else {
zipFile.extractFile(fileHeader,DestinationFolderPath);
}
}
} catch (ZipException e) {
e.printStackTrace();
}
}
使用extractAll(destination)
方法提取文件和目录。 如果您想手动执行此操作,请尝试以下操作:
public void unzip(File zip, String destinationFolderPath) throws net.lingala.zip4j.exception.ZipException {
ZipFile zipFile = new ZipFile(zip);
List<FileHeader> fileHeaders = zipFile.getFileHeaders();
for(FileHeader fileHeader : fileHeaders) {
if (fileHeader.isDirectory()) {
System.out.println(destinationFolderPath + fileHeader.getFileName());
File f = new File(destinationFolderPath + fileHeader.getFileName());
f.mkdirs(); // mkdirs() is different from mkdir()
zipFile.extractFile(fileHeader, f.toString());
}else {
zipFile.extractFile(fileHeader, destinationFolderPath);
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.