easyexcel导出Bigdecimal数据格式问题

//可以避免amount为0时,excel显示为.00的问题
@NumberFormat("#0.00")
private BigDecimal amount;

//设置千分位
@NumberFormat("#,##0.00"),即可设置千分位并保留两位小数。

// 也可以通过hutool工具包
NumberUtil.decimalFormat(",##0.00", number);

// 也可以通过自定义序列化器的方式来实现
@JsonSerialize(using = BigDecimalSerializer.class)
private BigDecimal payMoney

import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.databind.JsonSerializer;
import com.fasterxml.jackson.databind.SerializerProvider;

import java.io.IOException;
import java.math.BigDecimal;
import java.text.DecimalFormat;
public class BigDecimalSerializer extends JsonSerializer<BigDecimal> {
    // 千分位格式
    private static final DecimalFormat FORMAT = new DecimalFormat("#,##0.00");
    // 非千分位格式
    private static final DecimalFormat FORMAT = new DecimalFormat("#0.00");

    @Override
    public void serialize(BigDecimal value, JsonGenerator gen, SerializerProvider serializers)
            throws IOException {
        if (value != null) {
            gen.writeString(FORMAT.format(value));
        }
    }
}



posted @ 2023-03-20 18:02  npe0  阅读(1324)  评论(0)    收藏  举报