Converter’ support class LocalDate Easy Excel 导出excel 出现LocalDate时间格式异常

异常
使用Alibaba Easy Excel 导出excel 出现LocalDate时间格式异常

com.alibaba.excel.exception.ExcelDataConvertException: Can not find
‘Converter’ support class LocalDate.

问题根因
查看doWrite(List data)的源码时发现Converter接口的convertToExcelData只实现了转换BigDecimal、Bolean、Byte[]、btye[]、Byte、Date、Double、File、Float、InputStream、Integer、Long、Short、URL几种类型

解决办法
用 converter = LocalDateConverter.class

@ExcelProperty(value = "支付时间",  converter = LocalDateConverter.class)
    private LocalDate payDate;
package com.person.common.localdateConver;

import com.alibaba.excel.converters.Converter;
import com.alibaba.excel.enums.CellDataTypeEnum;
import com.alibaba.excel.metadata.CellData;
import com.alibaba.excel.metadata.GlobalConfiguration;
import com.alibaba.excel.metadata.property.ExcelContentProperty;

import java.time.LocalDate;
import java.time.format.DateTimeFormatter;

/**excel 导入 类型转换器yyyy-MM-dd
 *  @ ExcelProperty(value = "结束时间",converter = LocalDateConverter.class)
 * @author zms
 * @date 2021-12-15
 **/
public class LocalDateConverter implements Converter<LocalDate> {

    @Override
    public Class supportJavaTypeKey() {
        return LocalDate.class;
    }

    @Override
    public CellDataTypeEnum supportExcelTypeKey() {
        return CellDataTypeEnum.STRING;
    }

    @Override
    public LocalDate convertToJavaData(CellData cellData, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception {
        return LocalDate.parse(cellData.getStringValue(), DateTimeFormatter.ofPattern("yyyy-MM-dd"));
    }

    @Override
    public CellData convertToExcelData(LocalDate value, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception {
        return new CellData(value.format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
    }
}
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
LocalDateJava 8中的日期类,用于表示日期,不包含时间和时区信息。要导出LocalDate类型,可以按照以下步骤进行操作: 1. 首先,确保您已经在代码中导入了java.time包,因为LocalDate类位于该包中。您可以在代码文件的开头添加以下导入语句: ```java import java.time.LocalDate; ``` 2. 在您希望使用LocalDate类型的地方,可以声明或初始化一个LocalDate对象。例如,您可以使用以下代码声明一个LocalDate变量: ```java LocalDate date; ``` 或者,您可以直接初始化一个LocalDate对象并赋值给变量: ```java LocalDate date = LocalDate.now(); ``` 在上述示例中,`LocalDate.now()`方法返回当前日期。 3. 现在,您可以在代码中使用LocalDate对象,例如获取日期的年、月、日等信息,或者执行日期的比较、格式化等操作。以下是一些示例用法: ```java int year = date.getYear(); int month = date.getMonthValue(); int day = date.getDayOfMonth(); LocalDate anotherDate = LocalDate.of(2022, 12, 31); boolean isBefore = date.isBefore(anotherDate); boolean isAfter = date.isAfter(anotherDate); String formattedDate = date.format(DateTimeFormatter.ofPattern("yyyy-MM-dd")); ``` 在上述示例中,`getYear()`、`getMonthValue()`和`getDayOfMonth()`方法用于获取日期的年、月和日。`of()`方法用于创建一个指定日期的LocalDate对象。`isBefore()`和`isAfter()`方法用于比较两个日期的先后顺序。`format()`方法用于将日期格式化为指定的字符串。 这样,您就可以成功导出和使用LocalDate类型了。请根据您的具体需求在代码中灵活使用LocalDate类提供的功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值