[英]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.