//可以避免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));
}
}
}