mirror of https://gitee.com/xiaonuobase/snowy
【更新】完善导出word的图片显示问题
parent
0ccaf15f40
commit
db9393b182
|
@ -1003,13 +1003,17 @@ public class SysUserServiceImpl extends ServiceImpl<SysUserMapper, SysUser> impl
|
|||
}
|
||||
String fileName = "SNOWY2.0系统B端用户信息清单.xlsx";
|
||||
List<SysUser> sysUserList = this.list(queryWrapper);
|
||||
if(ObjectUtil.isEmpty(sysUserList)) {
|
||||
throw new CommonException("无数据可导出");
|
||||
}
|
||||
transService.transBatch(sysUserList);
|
||||
sysUserList = CollectionUtil.sort(sysUserList, Comparator.comparing(SysUser::getOrgId));
|
||||
List<SysUserExportResult> sysUserExportResultList = sysUserList.stream()
|
||||
.map(sysUser -> {
|
||||
SysUserExportResult sysUserExportResult = new SysUserExportResult();
|
||||
BeanUtil.copyProperties(sysUser, sysUserExportResult);
|
||||
sysUserExportResult.setGroupName(sysUserExportResult.getOrgName());
|
||||
sysUserExportResult.setGroupName(ObjectUtil.isNotEmpty(sysUserExportResult.getOrgName())?
|
||||
sysUserExportResult.getOrgName():"无组织");
|
||||
// 状态枚举转为文字
|
||||
sysUserExportResult.setUserStatus(sysUserExportResult.getUserStatus()
|
||||
.equalsIgnoreCase(SysUserStatusEnum.ENABLE.getValue())?"正常":"停用");
|
||||
|
@ -1124,13 +1128,20 @@ public class SysUserServiceImpl extends ServiceImpl<SysUserMapper, SysUser> impl
|
|||
File.separator + "userExportTemplate.docx"));
|
||||
// 构造填充的参数
|
||||
Map<String, Object> map = BeanUtil.beanToMap(sysUser);
|
||||
map.put("avatar", new ImageEntity(ImgUtil.toBytes(ImgUtil.toImage(StrUtil.split(sysUser.getAvatar(),
|
||||
StrUtil.COMMA).get(1)), ImgUtil.IMAGE_TYPE_PNG), 120, 160));
|
||||
String avatarBase64;
|
||||
if(ObjectUtil.isNotEmpty(sysUser.getAvatar())) {
|
||||
avatarBase64 = sysUser.getAvatar();
|
||||
} else {
|
||||
avatarBase64 = CommonAvatarUtil.generateImg(sysUser.getAvatar());
|
||||
}
|
||||
ImageEntity imageEntity = new ImageEntity(ImgUtil.toBytes(ImgUtil.toImage(StrUtil
|
||||
.split(avatarBase64, StrUtil.COMMA).get(1)), ImgUtil.IMAGE_TYPE_PNG), 120, 160);
|
||||
map.put("avatar", imageEntity);
|
||||
map.put("exportDateTime", DateUtil.format(DateTime.now(), DatePattern.CHINESE_DATE_PATTERN));
|
||||
// 生成doc
|
||||
XWPFDocument doc = WordExportUtil.exportWord07(destTemplateFile.getAbsolutePath(), map);
|
||||
// 生成临时导出文件
|
||||
resultFile = FileUtil.file(FileUtil.getTmpDir() + File.separator + sysUser.getName() + "个人信息.docx");
|
||||
resultFile = FileUtil.file(FileUtil.getTmpDir() + File.separator + "SNOWY2.0系统B端用户信息_" + sysUser.getName() + ".docx");
|
||||
// 写入
|
||||
BufferedOutputStream outputStream = FileUtil.getOutputStream(resultFile);
|
||||
doc.write(outputStream);
|
||||
|
|
Binary file not shown.
|
@ -12,11 +12,6 @@
|
|||
*/
|
||||
package vip.xiaonuo;
|
||||
|
||||
import com.alibaba.excel.EasyExcel;
|
||||
import com.alibaba.excel.read.listener.PageReadListener;
|
||||
import vip.xiaonuo.common.exception.CommonException;
|
||||
import vip.xiaonuo.sys.modular.user.param.SysUserImportParam;
|
||||
|
||||
/**
|
||||
* TestMain方法
|
||||
*
|
||||
|
@ -24,16 +19,7 @@ import vip.xiaonuo.sys.modular.user.param.SysUserImportParam;
|
|||
* @date 2022/9/17 17:10
|
||||
*/
|
||||
public class Test {
|
||||
public static void main(String[] args) {
|
||||
try {
|
||||
EasyExcel.read("D://import.xlsx", SysUserImportParam.class, new PageReadListener<SysUserImportParam>(dataList -> {
|
||||
for (SysUserImportParam sysUserImportParam : dataList) {
|
||||
System.out.println(sysUserImportParam);
|
||||
}
|
||||
})).sheet().headRowNumber(2).doRead();
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
throw new CommonException("文件导入失败");
|
||||
}
|
||||
public static void main(String[] args) throws Exception {
|
||||
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue