StringRecordHandler.java 1.3 KB
Newer Older
庄家钜's avatar
庄家钜 已提交
1 2 3 4 5 6 7 8
package com.alibaba.excel.analysis.v03.handlers;

import org.apache.poi.hssf.record.Record;
import org.apache.poi.hssf.record.StringRecord;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.alibaba.excel.analysis.v03.IgnorableXlsRecordHandler;
庄家钜's avatar
庄家钜 已提交
9
import com.alibaba.excel.context.xls.XlsReadContext;
庄家钜's avatar
庄家钜 已提交
10
import com.alibaba.excel.metadata.CellData;
庄家钜's avatar
庄家钜 已提交
11
import com.alibaba.excel.read.metadata.holder.xls.XlsReadSheetHolder;
庄家钜's avatar
庄家钜 已提交
12 13 14 15 16 17

/**
 * Record handler
 *
 * @author Dan Zheng
 */
18
public class StringRecordHandler extends AbstractXlsRecordHandler implements IgnorableXlsRecordHandler {
庄家钜's avatar
庄家钜 已提交
19 20 21 22 23 24
    private static final Logger LOGGER = LoggerFactory.getLogger(StringRecordHandler.class);

    @Override
    public void processRecord(XlsReadContext xlsReadContext, Record record) {
        // String for formula
        StringRecord srec = (StringRecord)record;
庄家钜's avatar
庄家钜 已提交
25 26
        XlsReadSheetHolder xlsReadSheetHolder = xlsReadContext.xlsReadSheetHolder();
        CellData tempCellData = xlsReadSheetHolder.getTempCellData();
庄家钜's avatar
庄家钜 已提交
27 28 29 30 31
        if (tempCellData == null) {
            LOGGER.warn("String type formula but no value found.");
            return;
        }
        tempCellData.setStringValue(srec.getString());
庄家钜's avatar
庄家钜 已提交
32 33
        xlsReadSheetHolder.getCellMap().put(tempCellData.getColumnIndex(), tempCellData);
        xlsReadSheetHolder.setTempCellData(null);
庄家钜's avatar
庄家钜 已提交
34 35
    }
}