cn.hutool.poi.excel.sax.ExcelSaxReader Maven / Gradle / Ivy
package cn.hutool.poi.excel.sax;
import cn.hutool.core.io.FileUtil;
import cn.hutool.poi.exceptions.POIException;
import java.io.File;
import java.io.InputStream;
/**
* Sax方式读取Excel接口,提供一些共用方法
* @author looly
*
* @param 子对象类型,用于标记返回值this
* @since 3.2.0
*/
public interface ExcelSaxReader {
// sheet r:Id前缀
String RID_PREFIX = "rId";
/**
* 开始读取Excel
*
* @param file Excel文件
* @param idOrRid Excel中的sheet id或者rid编号,rid必须加rId前缀,例如rId1,如果为-1处理所有编号的sheet
* @return this
* @throws POIException POI异常
*/
T read(File file, String idOrRid) throws POIException;
/**
* 开始读取Excel,读取结束后并不关闭流
*
* @param in Excel流
* @param idOrRid Excel中的sheet id或者rid编号,rid必须加rId前缀,例如rId1,如果为-1处理所有编号的sheet
* @return this
* @throws POIException POI异常
*/
T read(InputStream in, String idOrRid) throws POIException;
/**
* 开始读取Excel,读取所有sheet
*
* @param path Excel文件路径
* @return this
* @throws POIException POI异常
*/
default T read(String path) throws POIException {
return read(FileUtil.file(path));
}
/**
* 开始读取Excel,读取所有sheet
*
* @param file Excel文件
* @return this
* @throws POIException POI异常
*/
default T read(File file) throws POIException {
return read(file, -1);
}
/**
* 开始读取Excel,读取所有sheet,读取结束后并不关闭流
*
* @param in Excel包流
* @return this
* @throws POIException POI异常
*/
default T read(InputStream in) throws POIException {
return read(in, -1);
}
/**
* 开始读取Excel
*
* @param path 文件路径
* @param rid Excel中的sheet rid编号,如果为-1处理所有编号的sheet
* @return this
* @throws POIException POI异常
*/
default T read(String path, int rid) throws POIException {
return read(FileUtil.file(path), rid);
}
/**
* 开始读取Excel
*
* @param path 文件路径
* @param rid Excel中的sheet rid编号,如果为-1处理所有编号的sheet
* @return this
* @throws POIException POI异常
*/
default T read(String path, String rid) throws POIException {
return read(FileUtil.file(path), rid);
}
/**
* 开始读取Excel
*
* @param file Excel文件
* @param rid Excel中的sheet rid编号,如果为-1处理所有编号的sheet
* @return this
* @throws POIException POI异常
*/
default T read(File file, int rid) throws POIException{
return read(file, String.valueOf(rid));
}
/**
* 开始读取Excel,读取结束后并不关闭流
*
* @param in Excel流
* @param rid Excel中的sheet rid编号,如果为-1处理所有编号的sheet
* @return this
* @throws POIException POI异常
*/
default T read(InputStream in, int rid) throws POIException{
return read(in, String.valueOf(rid));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy