afterTurn easypoi导出一对多(图片)

导出结果样excel例

使用到的注解

 @Excel(name = "日期", needMerge = true,format = "yyyy-MM-dd")
 @Excel(name = "班次", needMerge = true, replace = {"白班_day", "夜班_night"})
 @ExcelCollection(name = "图片上传")
 @Excel(name = "图片上传", type = 2, width = 60, height = 60, imageType = 2)
// type=2该字段类型为图片;imageType=2表示从数据库中读取;width = 60, height = 60表示占单元格大小。

实体类

public class Record
    @Excel(name = "日期", needMerge = true,format = "yyyy-MM-dd")
    @JSONField(format = "yyyy-MM-dd")
    private Date operationDate;

    @Excel(name = "班次", needMerge = true, replace = {"白班_day", "夜班_night"})
    private String operatorShift;
 
    @TableField(typeHandler = FastjsonTypeHandler.class)
    private List<String> attachment;// 存放图片链接 保存到数据库

    @TableField(exist = false)
    @ExcelCollection(name = "图片上传")
    private List<DD> imgFile;// 用于导出图片

    @Data
    public static class DD  {
        @Excel(name = "图片上传", type = 2, width = 60, height = 60, imageType = 2)
        private byte[] bytes;
    }
}

图片本质上是byte[],如果private List<DD> imgFile改写为private List<byte[]> imgFile,导出时不会成功(只是大体debug了下,还没仔细看)。我的解决方法就是将byte[]封装到对象中然后导出。

处理图片的代码之后有时间贴一下,百度一下也可以搜索到

  • 7
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值