org.dromara.hutool.poi.excel.ExcelFileUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hutool-poi Show documentation
Show all versions of hutool-poi Show documentation
Hutool POI工具类(对Office文档、OFD等操作)
/*
* Copyright (c) 2023 looly([email protected])
* Hutool is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
* https://license.coscl.org.cn/MulanPSL2
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
*/
package org.dromara.hutool.poi.excel;
import org.dromara.hutool.core.io.IORuntimeException;
import org.apache.poi.poifs.filesystem.FileMagic;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
/**
* Excel文件工具类
*
* @author looly
* @since 4.2.1
*/
public class ExcelFileUtil {
// ------------------------------------------------------------------------------------------------ isXls
/**
* 是否为XLS格式的Excel文件(HSSF)
* XLS文件主要用于Excel 97~2003创建
* 此方法会自动调用{@link InputStream#reset()}方法
*
* @param in excel输入流
* @return 是否为XLS格式的Excel文件(HSSF)
*/
public static boolean isXls(final InputStream in) {
return FileMagic.OLE2 == getFileMagic(in);
}
/**
* 是否为XLSX格式的Excel文件(XSSF)
* XLSX文件主要用于Excel 2007+创建
* 此方法会自动调用{@link InputStream#reset()}方法
*
* @param in excel输入流
* @return 是否为XLSX格式的Excel文件(XSSF)
*/
public static boolean isXlsx(final InputStream in) {
return FileMagic.OOXML == getFileMagic(in);
}
/**
* 是否为XLSX格式的Excel文件(XSSF)
* XLSX文件主要用于Excel 2007+创建
*
* @param file excel文件
* @return 是否为XLSX格式的Excel文件(XSSF)
* @since 5.4.4
*/
public static boolean isXlsx(final File file) {
try {
return FileMagic.valueOf(file) == FileMagic.OOXML;
} catch (final IOException e) {
throw new IORuntimeException(e);
}
}
/**
* {@link java.io.PushbackInputStream}
* PushbackInputStream的markSupported()为false,并不支持mark和reset
* 如果强转成PushbackInputStream在调用FileMagic.valueOf(inputStream)时会报错
* {@link FileMagic}
* 报错内容:getFileMagic() only operates on streams which support mark(int)
* 此处修改成 final InputStream in = FileMagic.prepareToCheckMagic(in)
*
* @param in {@link InputStream}
* @author kefan.qu
*/
private static FileMagic getFileMagic(InputStream in) {
final FileMagic magic;
in = FileMagic.prepareToCheckMagic(in);
try {
magic = FileMagic.valueOf(in);
} catch (final IOException e) {
throw new IORuntimeException(e);
}
return magic;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy