top.coos.poi.excel.WorkbookUtil Maven / Gradle / Ivy
package top.coos.poi.excel;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;
import top.coos.core.io.FileUtil;
import top.coos.core.io.IORuntimeException;
import top.coos.core.io.IoUtil;
import top.coos.poi.exceptions.POIException;
import top.coos.util.StringUtil;
/**
* Excel工作簿{@link Workbook}相关工具类
*
* @since 4.0.7
*
*/
public class WorkbookUtil {
/**
* 加载工作簿
*
* @param excelFilePath Excel文件路径,绝对路径或相对于ClassPath路径
* @return {@link Workbook}
* @since 3.1.1
*/
public static Workbook loadBook(String excelFilePath) {
return loadBook(FileUtil.file(excelFilePath), null);
}
/**
* 加载工作簿
*
* @param excelFile Excel文件
* @return {@link Workbook}
*/
public static Workbook loadBook(File excelFile) {
return loadBook(excelFile, null);
}
/**
* 加载工作簿,只读模式
*
* @param excelFile Excel文件
* @param password Excel工作簿密码,如果无密码传{@code null}
* @return {@link Workbook}
*/
public static Workbook loadBook(File excelFile, String password) {
return loadBook(FileUtil.getInputStream(excelFile), password, true);
}
/**
* 加载工作簿
*
* @param in Excel输入流
* @param closeAfterRead 读取结束是否关闭流
* @return {@link Workbook}
*/
public static Workbook loadBook(InputStream in, boolean closeAfterRead) {
return loadBook(in, null, closeAfterRead);
}
/**
* 加载工作簿
*
* @param in Excel输入流
* @param password 密码
* @param closeAfterRead 读取结束是否关闭流
* @return {@link Workbook}
* @since 4.0.3
*/
public static Workbook loadBook(InputStream in, String password, boolean closeAfterRead) {
try {
return WorkbookFactory.create(IoUtil.toMarkSupportStream(in), password);
} catch (Exception e) {
throw new POIException(e);
} finally {
if (closeAfterRead) {
IoUtil.close(in);
}
}
}
/**
* 根据文件路径创建新的工作簿,文件路径
*
* @param destFilePath 目标文件路径,文件可以不存在,通过扩展名判断Workbook类型
* @return {@link Workbook}
* @since 3.2.0
*/
public static Workbook createBook(String destFilePath) {
Workbook workbook;
if (StringUtil.endWithIgnoreCase(destFilePath, "xlsx")) {
workbook = new org.apache.poi.xssf.usermodel.XSSFWorkbook();
} else {
workbook = new org.apache.poi.hssf.usermodel.HSSFWorkbook();
}
return workbook;
}
/**
* 根据文件路径创建新的工作簿
*
* @param destFile 目标文件,文件可以不存在
* @return {@link Workbook}
* @since 3.2.0
*/
public static Workbook createBook(File destFile) {
return createBook(destFile.getName());
}
/**
* 将Excel Workbook刷出到输出流,不关闭流
*
* @param book {@link Workbook}
* @param out 输出流
* @throws IORuntimeException IO异常
* @since 3.2.0
*/
public static void writeBook(Workbook book, OutputStream out) throws IORuntimeException {
try {
book.write(out);
} catch (IOException e) {
throw new IORuntimeException(e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy