java关于文件的工具类以及Excel高效导出

本文介绍了一套Java开发中常用的文件及文件夹操作工具类,包括文件夹创建、文件存在性判断、文件删除、文件压缩等功能。同时,提供了基于POI和JXLS的Excel导出工具类,支持单个和多个Sheet页的导出,并详细展示了使用模板导出Excel的具体步骤和示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java开发中的一些关于文件和文件夹操作的工具类:

1、文件以及文件夹工具类:

package com.hpe.poi.util;

import org.apache.commons.io.FileUtils;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.StringTokenizer;

/**
 * 文件以及文件夹工具类
 * Created by Administrator on 2018/11/30 0030.
 */
public class FileUtil {

    /**
     * 创建文件夹(循环创建)
     * @param dirPath 需要创建的文件夹
     */
    public static void dirExists(String dirPath) {

        StringTokenizer st =new StringTokenizer(dirPath,"/");

        String   path1 = st.nextToken()+"/";

        String   path2 = path1;

        while(st.hasMoreTokens()){

            path1 = st.nextToken()+"/";

            path2 += path1;

            File file   =   new File(path2);

            if(!file.exists()){

                file.mkdir();

            }
        }
    }

    /**
     * 判断文件是否存在,不存在创建
     * @param file 需要创建的文件
     */
    public static void judeFileExists(File file) {

        if (file.exists() == false){

            try {
                file.createNewFile();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

    /**
     * 判断文件夹是否存在,不存在创建。
     * @param file 需要创建的文件夹
     */
    public static void judeDirExists(File file) {

        if (file.exists() == false){

            file.mkdir();
        }
    }

    /**
     * 删除文件
     * @param fileRoot 删除文件路径
     */
    public static void deleteFile(String fileRoot) {

        File file = new File(fileRoot);

        if(file.exists() && file.isFile()){
            //删除文件
            file.delete();
        }
    }


    /**
     * 压缩文件路径
     * @param compressFileName 压缩文件名称
     * @param compressFolder 压缩文件夹路径
     */
    public static void compressFolder(String compressFileName,String compressFolder) {

        try {

            //压缩文件夹路径
            FileOutputStream fos1 = new FileOutputStream(new File(compressFolder+".zip"));

            //压缩文件
            ZipUtils.toZip(compressFolder, fos1,true);

        } catch (Exception e) {
            e.printStackTrace();
        }

    }


    /**
     * 删除文件夹:支持多层文件夹删除
     * @param folderPath 文件夹路径
     */
    public static void removeFolder(String folderPath) {

        try {

            //需要删除的文件夹
            File file = new File(folderPath);
            //执行删除
            FileUtils.deleteDirectory(file);

        } catch (Exception e) {

            e.printStackTrace();
        }
    }

}

2、压缩文件工具类

package com.hpe.poi.util;

import java.io.*;
import java.util.List;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;

/**
 * 压缩文件工具类
 */
public class ZipUtils {

    private static final int  BUFFER_SIZE = 2 * 1024;

    /**
     * 压缩成ZIP(压缩文件夹) 方法1
     * @param compressFolder 压缩文件夹路径
     * @param out    压缩文件输出流
     * @param KeepDirStructure  是否保留原来的目录结构,true:保留目录结构;
     *                          false:所有文件跑到压缩包根目录下(注意:不保留目录结构可能会出现同名文件,会压缩失败)
     * @throws RuntimeException 压缩失败会抛出运行时异常
     */
    public static void toZip(String compressFolder, OutputStream out, boolean KeepDirStructure)

            throws RuntimeException{

        ZipOutputStream zos = null ;

        try {
            zos = new ZipOutputStream(out);
            //创建文件夹
            File sourceFile = new File(compressFolder);

            compress(sourceFile,zos,sourceFile.getName(),KeepDirStructure);

        } catch (Exception e) {
            e.printStackTrace();
            //throw new BusinessException("zip文件生成失败!");

        }finally{
            if(zos != null){
                try {
                    zos.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }

    }

    /**
     * 压缩成ZIP(压缩单个文件) 方法2
     * @param compressFileList 需要压缩的文件列表
     * @param out           压缩文件输出流
     * @throws RuntimeException 压缩失败会抛出运行时异常
     */
    public static void toZip(List<File> compressFileList , OutputStream out)throws RuntimeException {

        ZipOutputStream zos = null ;

        try {
            zos = new ZipOutputStream(out);
            for (File srcFile : compressFileList) {
                byte[] buf = new byte[BUFFER_SIZE];
                zos.putNextEntry(new ZipEntry(srcFile.getName()));
                int len;
                FileInputStream in = new FileInputStream(srcFile);
                while ((len = in.read(buf)) != -1){
                    zos.write(buf, 0, len);
                }
                zos.closeEntry();
                in.close();
            }

        } catch (Exception e) {
            e.printStackTrace();
            //throw new BusinessException("zip文件生成失败!");

        }finally{
            if(zos != null){
                try {
                    zos.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }

    /**
     * 递归压缩方法
     * @param sourceFile 源文件
     * @param zos        zip输出流
     * @param name       压缩后的名称
     * @param KeepDirStructure  是否保留原来的目录结构,true:保留目录结构;
     *                          false:所有文件跑到压缩包根目录下(注意:不保留目录结构可能会出现同名文件,会压缩失败)
     * @throws Exception
     **/
    private static void compress(File sourceFile, ZipOutputStream zos, String name,
                                 boolean KeepDirStructure) throws Exception{
        byte[] buf = new byte[BUFFER_SIZE];
        if(sourceFile.isFile()){
            // 向zip输出流中添加一个zip实体,构造器中name为zip实体的文件的名字
            zos.putNextEntry(new ZipEntry(name));
            // copy文件到zip输出流中
            int len;
            FileInputStream in = new FileInputStream(sourceFile);
            while ((len = in.read(buf)) != -1){
                zos.write(buf, 0, len);
            }
            // Complete the entry
            zos.closeEntry();
            in.close();
        } else {
            File[] listFiles = sourceFile.listFiles();
            if(listFiles == null || listFiles.length == 0){
                // 需要保留原来的文件结构时,需要对空文件夹进行处理
                if(KeepDirStructure){
                    // 空文件夹的处理
                    zos.putNextEntry(new ZipEntry(name + "/"));
                    // 没有文件,不需要文件的copy
                    zos.closeEntry();
                }

            }else {
                for (File file : listFiles) {
                    // 判断是否需要保留原来的文件结构
                    if (KeepDirStructure) {
                        // 注意:file.getName()前面需要带上父文件夹的名字加一斜杠,
                        // 不然最后压缩包中就不能保留原来的文件结构,即:所有文件都跑到压缩包根目录下了
                        compress(file, zos, name + "/" + file.getName(),KeepDirStructure);
                    } else {
                        compress(file, zos, file.getName(),KeepDirStructure);
                    }

                }

            }

        }

    }


    public static void main(String[] args) throws Exception {

        /** 文件夹压缩测试-测试压缩方法1  */
        FileOutputStream fos1 = new FileOutputStream(new File("E:/ftp/order/export/temp/6.28-7.4.zip"));

        ZipUtils.toZip("E:/ftp/order/export/temp/6.28-7.4/", fos1,true);

        //删除文件夹
        /*File file = new File("E:/ftp/order/export/temp/6.28-7.4执行单/");
        long start = System.currentTimeMillis();
        FileUtils.deleteDirectory(file);
        long end = System.currentTimeMillis();
        System.out.println("删除文件夹成功,消耗时间:"+(end - start)+"ms");*/

        /** 具体文件压缩-测试压缩方法2  */
        /*List<File> fileList = new ArrayList<>();

        fileList.add(new File("D:/Java/jdk1.7.0_45_64bit/bin/java.exe"));

        fileList.add(new File("D:/Java/jdk1.7.0_45_64bit/bin/java.exe"));

        FileOutputStream fos2 = new FileOutputStream(new File("c:test.zip"));

        ZipUtils.toZip(fileList, fos2);*/

    }
}

3、导出excel工具类(主要针对poi和jxls导出excel)

      使用此工具类需要的依赖:

   

<!-- ##################jxls导出用##################### -->
      <dependency>
          <groupId>net.sf.jxls</groupId>
          <artifactId>jxls-core</artifactId>
          <version>1.0.6</version>
      </dependency>

      <dependency>
          <groupId>commons-logging</groupId>
          <artifactId>commons-logging</artifactId>
          <version>1.2</version>
      </dependency>

      <dependency>
          <groupId>org.apache.commons</groupId>
          <artifactId>commons-jexl</artifactId>
          <version>2.1.1</version>
      </dependency>

      <dependency>
          <groupId>commons-digester</groupId>
          <artifactId>commons-digester</artifactId>
          <version>2.1</version>
      </dependency>

      <dependency>
          <groupId>commons-beanutils</groupId>
          <artifactId>commons-beanutils</artifactId>
          <version>1.9.3</version>
      </dependency>



      <!-- #########poi和jxls导出都需要jar############### -->
      <dependency>
          <groupId>org.apache.poi</groupId>
          <artifactId>poi</artifactId>
          <version>3.17</version>
      </dependency>

      <dependency>
          <groupId>org.apache.poi</groupId>
          <artifactId>poi-ooxml</artifactId>
          <version>3.17</version>
      </dependency>

      <dependency>
          <groupId>org.apache.xmlbeans</groupId>
          <artifactId>xmlbeans</artifactId>
          <version>2.6.0</version>
      </dependency>

      <dependency>
          <groupId> org.apache.commons</groupId>
          <artifactId>commons-collections4</artifactId>
          <version>4.1</version>
      </dependency>

      <!-- #####################poi导出必须包####################### -->
      <dependency>
          <groupId>org.apache.poi</groupId>
          <artifactId>ooxml-schemas</artifactId>
          <version>1.3</version>
      </dependency>

      <!-- #####################servlet支持######################## -->
      <dependency>
          <groupId>javax.servlet</groupId>
          <artifactId>servlet-api</artifactId>
          <version>2.5</version>
          <scope>provided</scope>
      </dependency>

      <!-- ####################io################################-->
      <dependency>
          <groupId>commons-io</groupId>
          <artifactId>commons-io</artifactId>
          <version>2.6</version>
      </dependency>

Sheet工具类:

package com.hpe.poi.util;


import net.sf.jxls.transformer.XLSTransformer;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.xssf.streaming.SXSSFCell;
import org.apache.poi.xssf.streaming.SXSSFRow;
import org.apache.poi.xssf.streaming.SXSSFSheet;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.io.*;
import java.util.List;
import java.util.Map;

/**
 * Created on 2017/5/18.
 */
public class SheetUtil {

    /**
     * 写xls
     * @param sheet
     * @param rowNum
     * @param cellValues
     */
    public static void writeRow(HSSFSheet sheet, int rowNum, String... cellValues) {
        HSSFRow row = sheet.createRow(rowNum);
        int col = 0;
        for (String value : cellValues) {
            HSSFCell cell = row.createCell(col++);
            cell.setCellValue(value);
        }
    }

    public static void mergeCell(HSSFSheet sheet, int rowStart, int colStart, int rowEnd, int colEnd) {

        sheet.addMergedRegion(new CellRangeAddress(rowStart, rowEnd, colStart, colEnd));
    }


    /**
     * 写xlsx(性能不佳)
     * @param sheet
     * @param rowNum
     * @param cellValues
     */
    public static void writeRowXlsx(XSSFSheet sheet, int rowNum, String... cellValues) {
        XSSFRow row = sheet.createRow(rowNum);
        int col = 0;
        for (String value : cellValues) {
            XSSFCell cell = row.createCell(col++);
            cell.setCellValue(value);
        }
    }

    public static void writeRowXlsxByList(XSSFSheet sheet, int rowNum, List cellValues) {
        XSSFRow row = sheet.createRow(rowNum);
        int col = 0;
        for (Object value : cellValues) {
            XSSFCell cell = row.createCell(col++);
            cell.setCellValue(value.toString());
        }
    }


    public static void mergeCellXlsx(XSSFSheet sheet, int rowStart, int colStart, int rowEnd, int colEnd) {
        sheet.addMergedRegion(new CellRangeAddress(rowStart, rowEnd, colStart, colEnd));
    }

    /**
     * 写大容量数据
     * @param sheet sheet页
     * @param rowStartNum 开始行
     * @param colStartNum 开始列
     * @param cellValues 填充数据
     */
    public static void writeRowExcelBySXSSF(SXSSFSheet sheet, int rowStartNum, int colStartNum, Object... cellValues) {
        SXSSFRow row = sheet.createRow(rowStartNum);
        for (Object value : cellValues) {
            SXSSFCell cell = row.createCell(colStartNum++);
            cell.setCellValue(value.toString());
        }
    }


    /**
     * 写数据
     * @param sheet sheet页
     * @param rowStartNum 开始行
     * @param colStartNum 开始列
     * @param cellValues 填充数据
     */
    public static void writeRowExcelListBySXSSF(SXSSFSheet sheet, int rowStartNum, int colStartNum, List cellValues) {
        //创建行
        SXSSFRow row = sheet.createRow(rowStartNum);

        //循环添加数据
        for (Object value : cellValues) {
            SXSSFCell cell = row.createCell(colStartNum++);
            cell.setCellValue(value.toString());
        }
    }

    /**
     * 插入到指定行列内
     * @param sheet
     * @param rowStart
     * @param colStart
     * @param rowEnd
     * @param colEnd
     */
    public static void mergeCellXlsxBySXSSF(SXSSFSheet sheet, int rowStart, int colStart, int rowEnd, int colEnd) {
        sheet.addMergedRegion(new CellRangeAddress(rowStart, rowEnd, colStart, colEnd));
    }

    public static void writeXlsxSXSSF(String fileName, List<String[]> list) {
        try {
            //输出文件名称
            InputStream is = new FileInputStream(fileName);
            //创建Excel文档对象
            XSSFWorkbook workbook = new XSSFWorkbook(is);
            SXSSFWorkbook wb = new SXSSFWorkbook(workbook);
            //获得工作表
            SXSSFSheet sheet = wb.getSheetAt(0);
            for (int i = 0; i < list.size(); i++) {
                SXSSFRow row = sheet.createRow(i);
                String[] str = list.get(i);
                for (int j = 0; j < str.length; j++) {
                    SXSSFCell cell = row.createCell(j);
                    cell.setCellValue(str[j]);
                }
            }
            OutputStream outputStream = new FileOutputStream(fileName);
            wb.write(outputStream);
            outputStream.flush();
            outputStream.close();
            wb.close();
        } catch (Exception e) {
            e.fillInStackTrace();
        }
    }

    /*public static Map<Integer, List<String[]>> readXlsx(String fileName) {
        Map<Integer, List<String[]>> map = new HashMap<Integer, List<String[]>>();
        try {
            InputStream is = new FileInputStream(fileName);
            XSSFWorkbook workbook = new XSSFWorkbook(is);
            //循环工作表Sheet
            for (int numSheet = 0; numSheet < workbook.getNumberOfSheets(); numSheet++) {
                XSSFSheet xssfSheet = workbook.getSheetAt(numSheet);
                if (xssfSheet == null) {
                    continue;
                }
                List<String[]> list = new ArrayList<String[]>();

                for (int row = 0; row <= xssfSheet.getLastRowNum(); row++) {
                    XSSFRow xssfRow = xssfSheet.getRow(row);
                    if (xssfRow == null) {
                        continue;
                    }
                    try {
                        String[] singleRow = new String[xssfRow.getLastCellNum()];
                        for (int column = 0; column < xssfRow.getLastCellNum(); column++) {
                            Cell cell = xssfRow.getCell(column, Row.MissingCellPolicy.CREATE_NULL_AS_BLANK);
                            switch (cell.getCellType()) {
                                case BLANK:
                                    singleRow[column] = "";
                                    break;
                                case BOOLEAN:
                                    singleRow[column] = Boolean.toString(cell.getBooleanCellValue());
                                    break;
                                case ERROR:
                                    singleRow[column] = "";
                                    break;
                                case FORMULA:
                                    cell.setCellType(STRING);
                                    singleRow[column] = cell.getStringCellValue();
                                    if (singleRow[column] != null) {
                                        singleRow[column] = singleRow[column].replaceAll("#N/A", "").trim();
                                    }
                                    break;
                                case NUMERIC:
                                    if (DateUtil.isCellDateFormatted(cell)) {
                                        singleRow[column] = String.valueOf(cell.getDateCellValue());
                                    } else {
                                        cell.setCellType(STRING);
                                        String temp = cell.getStringCellValue();
                                        //判断是否包含小数点,如果不含小数点,则以字符串读取,如果含小数点,则转换为Double类型的字符串
                                        if (temp.contains(".")) {
                                            singleRow[column] = String.valueOf(new Double(temp)).trim();
                                        } else {
                                            singleRow[column] = temp.trim();
                                        }
                                    }

                                    break;
                                case STRING:
                                    singleRow[column] = cell.getStringCellValue().trim();
                                    break;
                                default:
                                    singleRow[column] = "";
                                    break;
                            }
                        }
                        list.add(singleRow);
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
                map.put(numSheet, list);

            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return map;
    }*/

    /**
     * jxls模板导出excel:一个sheet页(效率比较高支持xls和xlsx格式)
     * @param templateFile 模板文件
     * @param context 导出数据
     * @param exportFilePath 导出文件位置
     */
    public static void jxlsExportExcelOneSheet(String templateFile,Map<String,Object> context,String exportFilePath) {

        try {

            XLSTransformer transformer = new XLSTransformer();

            transformer.transformXLS(templateFile, context, exportFilePath);


        } catch (Exception e) {

            e.printStackTrace();
        }
    }

    /**
     * jxls模板:多sheet导出(效率比较高支持xls和xlsx格式)
     * @param inputStream 文件输入流对象
     * @param dataLists sheet需要数据
     * @param sheetNamesList sheet名称集合
     * @param beanName  模板用于遍历的名称,比如:模板遍历的对象为list,这个属性值就应该设置为list
     * @param beanParams 这个参数是在如果传入的objects还与其他的对象关联的时候使用的,该参数是一个HashMap类型的参数,如果不使用的话,直接传入new HashMap()即可
     * @param startSheetNum 传入0即可,即SheetNo从0开始
     */
    public static Workbook jxlsExportMultipleSheet(InputStream inputStream, List dataLists, List sheetNamesList, String beanName, Map beanParams, int startSheetNum){

        Workbook workbook = null;

        try{

            //创建XLSTransformer对象
            XLSTransformer transformer = new XLSTransformer();

            //调用引擎生成excel报表
            workbook = (Workbook)transformer.transformMultipleSheetsList(inputStream,dataLists,sheetNamesList,beanName,beanParams,startSheetNum);

        }catch (Exception e){

            e.printStackTrace();
        }

        return workbook;
    }

    /**
     * jxls循环删除多个sheet
     * @param workbook Workbook对象
     * @param sheetNames sheet名称数组
     * @return
     */
    public static Workbook removeSheets(Workbook workbook,String[] sheetNames){

        //循环删除多余的sheet
        for (String sheetName : sheetNames){

            workbook.removeSheetAt(workbook.getSheetIndex(sheetName));
        }

        return workbook;

    }

}

下面是针对导出excel工具类,使用模板导出excel中一个sheet页和一个excel中多个sheet页的简单demo:

(1)、模板导出一个excel中一个sheet页,使用jxlsExportExcelOneSheet类

目录结构如图所示,模板文件在resource文件夹下(java项目)

  首先创建模板导出用模板样式如下图:

书写测试类进行工具类的测试:

    /**
     * 单Sheet Excel导出测试
     */
    @Test
    public void oneSheetExportTest(){

        //模板文件(当前项目下的模板)
        String templateFile = "src/main/resource/template.xlsx";

        Map<String, Object> context = new HashMap<String, Object>();

        List<User> userList = new ArrayList<User>();

        User user1 = new User();

        user1.setId(11);

        user1.setUserName("李四");

        user1.setPassword("lisi");

        user1.setAge(25);

        userList.add(user1);

        User user2 = new User();

        user2.setId(13);

        user2.setUserName("王五");

        user2.setPassword("wangwu");

        user2.setAge(25);

        userList.add(user2);

        context.put("resultList", userList);

        //导出文件
        String exportFilePath = "G:/simple.xlsx";

        SheetUtil.jxlsExportExcelOneSheet(templateFile,context,exportFilePath);

    }

执行导出输出结果:

(2)、jxls根据模板导出多Sheet页,首先模板文件存放位置和单sheet导出模板位置相同在:src/main/resource/multiSheet.xlsx

(注意:为了导出后不删除多余的sheet页,再制作模板的时候,就只留一个sheet页),模板样式:

 

/**
     * jxls多sheet导出测试
     */
    @Test
    public void multipleSheetsExportTest(){

        try{

            //模板文件(当前项目下的模板)
            String templateFile = "src/main/resource/multiSheet.xlsx";

            FileInputStream is = new FileInputStream(templateFile);

            List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();

            Map<String, Object> map1 = new HashMap<String, Object>();

            map1.put("name", "华为");

            map1.put("price", "3000");

            map1.put("desc", "全面屏");

            map1.put("remark", "中文测试");

            Map<String, Object> map2 = new HashMap<String, Object>();

            map2.put("name", "努比亚");

            map2.put("price", "2000");

            map2.put("desc", "无边框");

            map2.put("remark", "测试中文");

            list.add(map1);

            list.add(map2);

            //封装数据map
            Map<String,Object> dataMap = new HashMap<String,Object>();
            //excel取得集合
            dataMap.put("dataList",list);
            //直接取属性
            dataMap.put("userName","zhangsan");

            List<Map<String,Object>> objects = new ArrayList<Map<String,Object>>();

            objects.add(dataMap);

            objects.add(dataMap);

            objects.add(dataMap);

            objects.add(dataMap);

            objects.add(dataMap);

            //sheet的名称
            List<String> listSheetNames = new ArrayList<String>();

            listSheetNames.add("测试1");

            listSheetNames.add("测试2");

            listSheetNames.add("测试3");

            listSheetNames.add("测试4");

            listSheetNames.add("测试5");

            //调用引擎生成excel报表
            Workbook workbook = SheetUtil.jxlsExportMultipleSheet(is, objects, listSheetNames, "list", new HashMap(), 0);

            //删除多余sheet
            //String[] sheetNames = {"sheet2","sheet3"};
            //workbook = SheetUtil.removeSheets(workbook,sheetNames);

            //workbook.removeSheetAt(workbook.getSheetIndex("sheet2"));
            //workbook.removeSheetAt(workbook.getSheetIndex("sheet3"));

            workbook.write(new FileOutputStream("G:/xlsExportUtils.xlsx"));

        }catch(Exception e){
            e.printStackTrace();
        }

    }

注意:程序中的

这些地方一定要和excel模板文件中相对应,否则会出错

导出测试结果:

导出成功;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值