package com.taover.easyexcel.converters.date; import java.math.BigDecimal; import java.util.Date; import org.apache.poi.ss.usermodel.DateUtil; import com.taover.easyexcel.converters.Converter; import com.taover.easyexcel.enums.CellDataTypeEnum; import com.taover.easyexcel.metadata.CellData; import com.taover.easyexcel.metadata.GlobalConfiguration; import com.taover.easyexcel.metadata.property.ExcelContentProperty; /** * Date and number converter * * @author Jiaju Zhuang */ public class DateNumberConverter implements Converter { @Override public Class supportJavaTypeKey() { return Date.class; } @Override public CellDataTypeEnum supportExcelTypeKey() { return CellDataTypeEnum.NUMBER; } @Override public Date convertToJavaData(CellData cellData, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) { if (contentProperty == null || contentProperty.getDateTimeFormatProperty() == null) { return DateUtil.getJavaDate(cellData.getNumberValue().doubleValue(), globalConfiguration.getUse1904windowing(), null); } else { return DateUtil.getJavaDate(cellData.getNumberValue().doubleValue(), contentProperty.getDateTimeFormatProperty().getUse1904windowing(), null); } } @Override public CellData convertToExcelData(Date value, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) { if (contentProperty == null || contentProperty.getDateTimeFormatProperty() == null) { return new CellData( BigDecimal.valueOf(DateUtil.getExcelDate(value, globalConfiguration.getUse1904windowing()))); } else { return new CellData(BigDecimal.valueOf( DateUtil.getExcelDate(value, contentProperty.getDateTimeFormatProperty().getUse1904windowing()))); } } }