cn.hutool.poi.excel.sax.ExcelSaxUtil Maven / Gradle / Ivy
package cn.hutool.poi.excel.sax;
import org.apache.poi.ss.usermodel.DataFormatter;
import org.apache.poi.xssf.model.SharedStringsTable;
import org.apache.poi.xssf.usermodel.XSSFRichTextString;
import cn.hutool.core.util.StrUtil;
/**
* Sax方式读取Excel相关工具类
*
* @author looly
*
*/
public class ExcelSaxUtil {
// 填充字符串
public static final char CELL_FILL_CHAR = '@';
// 列的最大位数
public static final int MAX_CELL_BIT = 3;
/**
* 根据数据类型获取数据
*
* @param cellDataType 数据类型枚举
* @param value 数据值
* @param sharedStringsTable {@link SharedStringsTable}
* @param numFmtIndex 数字格式索引
* @param numFmtString 数字格式名
* @return 数据值
*/
public static String getDataValue(CellDataType cellDataType, String value, SharedStringsTable sharedStringsTable, int numFmtIndex, String numFmtString) {
if(null == value) {
return null;
}
String thisStr;
switch (cellDataType) {
case BOOL:
char first = value.charAt(0);
thisStr = (first == '0') ? "FALSE" : "TRUE";
break;
case ERROR:
thisStr = StrUtil.format("\\\"ERROR: {} ", value);
break;
case FORMULA:
thisStr = StrUtil.format("\"{}\"", value);
break;
case INLINESTR:
thisStr = new XSSFRichTextString(value.toString()).toString();
break;
case SSTINDEX:
try {
final int index = Integer.parseInt(value);
thisStr = new XSSFRichTextString(sharedStringsTable.getEntryAt(index)).getString();
} catch (NumberFormatException e) {
thisStr = value;
}
break;
case NUMBER:
thisStr = formatCellContent(value, numFmtIndex, numFmtString);
thisStr = thisStr.replace("_", "").trim();
break;
case DATE:
thisStr = formatCellContent(value, numFmtIndex, numFmtString);
break;
default:
thisStr = StrUtil.EMPTY;
break;
}
return thisStr;
}
/**
* 格式化数字或日期值
*
* @param value 值
* @param numFmtIndex 数字格式索引
* @param numFmtString 数字格式名
* @return 格式化后的值
*/
public static String formatCellContent(String value, int numFmtIndex, String numFmtString) {
if (null != numFmtString) {
try {
value = new DataFormatter().formatRawCellContents(Double.parseDouble(value), numFmtIndex, numFmtString);
} catch (NumberFormatException e) {
// ignore
}
}
return value;
}
/**
* 计算两个单元格之间的单元格数目(同一行)
*
* @param preRef 前一个单元格位置,例如A1
* @param ref 当前单元格位置,例如A8
* @return 同一行中两个单元格之间的空单元格数
*/
public static int countNullCell(String preRef, String ref) {
// excel2007最大行数是1048576,最大列数是16384,最后一列列名是XFD
// 数字代表列,去掉列信息
String preXfd = preRef.replaceAll("\\d+", "");
String xfd = ref.replaceAll("\\d+", "");
// A表示65,@表示64,如果A算作1,那@代表0
// 填充最大位数3
preXfd = StrUtil.fillBefore(preXfd, CELL_FILL_CHAR, MAX_CELL_BIT);
xfd = StrUtil.fillBefore(xfd, CELL_FILL_CHAR, MAX_CELL_BIT);
char[] preLetter = preXfd.toCharArray();
char[] letter = xfd.toCharArray();
// 用字母表示则最多三位,每26个字母进一位
int res = (letter[0] - preLetter[0]) * 26 * 26 + (letter[1] - preLetter[1]) * 26 + (letter[2] - preLetter[2]);
return res - 1;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy