JAVA将本地文件夹内容生成压缩包

// 将要被压缩的文件夹路径
String folderPath = "D:/downloadResult/";
// 压缩后生成的压缩文件路径及临时文件名
String zipFilePath = "D:/uploadResult/" + parkCode + ".zip";
dataReportUtil.isFilePath("D:/uploadResult");//判断目录是否存在
zipFolder(folderPath, zipFilePath);

/**
     * 打包压缩文件夹
     *
     * @param folderPath 文件夹路径
     * @param zipFilePath 压缩后的文件路径
     * @throws IOException IO异常
     */
    public static void zipFolder(String folderPath, String zipFilePath) throws IOException {
        FileOutputStream fos = null;
        ZipOutputStream zos = null;
        try {
            fos = new FileOutputStream(zipFilePath);
            zos = new ZipOutputStream(fos);

            // 递归遍历整个文件夹并添加到压缩包
            addFolderToZip("", new File(folderPath), zos);
        } finally {
            if (zos != null) {
                zos.close();
            }
            if (fos != null) {
                fos.close();
            }
        }
    }

  /**
     * 将文件夹及其中的文件递归添加到压缩流中
     *
     * @param parentPath 父级路径
     * @param folder 文件夹
     * @param zos Zip输出流
     * @throws FileNotFoundException 文件未找到异常
     * @throws IOException IO异常
     */
    private static void addFolderToZip(String parentPath, File folder, ZipOutputStream zos) throws FileNotFoundException, IOException {
        for (File file : folder.listFiles()) {
            if (file.isDirectory()) {
                // 递归添加子文件夹中的文件
                addFolderToZip(folder.getName() + "/", file, zos);
            } else {
                FileInputStream fis = null;
                try {
                    fis = new FileInputStream(file);

                    //判断是否为json数据
                    String zipName = file.toString().contains(".json") ? file.getName() : folder.getName() + "/" + file.getName();
                    // 新建Zip条目并将输入流加入到Zip包中
                    ZipEntry zipEntry = new ZipEntry(zipName);
                    zos.putNextEntry(zipEntry);

                    byte[] bytes = new byte[1024];
                    int length;
                    while ((length = fis.read(bytes)) >= 0) {
                        zos.write(bytes, 0, length);
                    }
                } finally {
                    if (fis != null) {
                        fis.close();
                    }
                }
            }
        }
    }

Java中,你可以使用Apache POI库来处理Excel文件,Apache Commons Compress库来进行压缩,以及java.nio.file包来操作文件和目录。以下是简单的步骤来实现这个功能: 1. 首先,需要添加依赖,如果你还没有的话: ```xml <dependencies> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>5.0.0</version> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-compress</artifactId> <version>1.21</version> </dependency> </dependencies> ``` 2. 使用`POIXMLDocumentFactory`打开Excel文件流: ```java FileInputStream fis = new FileInputStream("path_to_your_excel_file.xlsx"); POIXMLDocument document = POIXMLDocument.load(fis); ``` 3. 获取工作表并将其内容保存到新的CSV文件中: ```java Workbook workbook = document.getWorkbook(); for (Sheet sheet : workbook) { String relativePath = "sheet_" + sheet.getSheetName() + ".csv"; FileOutputStream fos = new FileOutputStream(new File(directoryPath, relativePath)); // ...将sheet的内容转换为CSV并写入fos... fos.close(); } ``` 这里假设你已经有了将Excel数据转换为CSV的方法。 4. 创建压缩包: ```java File dirToZip = new File(directoryPath); // 文件夹路径 try (FileArchiveOutputStream out = new FileArchiveOutputStream( new JarOutputStream(new FileOutputStream("compressed_package.zip"), StandardCharsets.UTF_8.newEncoder()))) { // 如果是JarOutputStream,则用jarEntry代替file.getName() out.addArchiveEntry(new ZipArchiveEntry(dirToZip.getAbsolutePath())); IOUtils.copyDirectory(dirToZip, out); } catch (IOException e) { throw new RuntimeException("Failed to create ZIP", e); } ``` 5. 关闭资源: ```java fis.close(); // 关闭原Excel文件流 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值