java的Excel导出,数组与业务字典匹配并去掉最后一个逗号

简介: java的Excel导出,数组与业务字典匹配并去掉最后一个逗号

 ♥️作者:小宋1021

🤵‍♂️个人主页:小宋1021主页

♥️坚持分析平时学习到的项目以及学习到的软件开发知识,和大家一起努力呀!!!

🎈🎈加油! 加油! 加油! 加油

🎈欢迎评论 💬点赞👍🏻 收藏 📂加关注+


首先展示导出结果,如图所示:

image.gif 编辑 image.gif 编辑

代码展示:

导出实体类:

由于不想和DO混用,就单独为导出的字段建立实体类,一方面是容易使用 @ExcelProperty注解,方便观察,另一方面是有些字段在数据库存的是业务字典的value,是Integer类型,我需要再定义一个String类型的字段来接收于业务字典匹配完成后的label的值并完成导出。

package com.todod.education.module.hr.controller.admin.teachermanage.vo;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import lombok.ToString;
@Schema(description = "管理后台 -  教师信息导出管理 Response VO")
@Data
@ExcelIgnoreUnannotated
@ToString(callSuper = true)
public class TeacherExportRespVO {
    @Schema(description = "教师姓名", example = "赵六")
    @ExcelProperty("教师姓名")
    private String teacherName;
    @Schema(description = "手机号", example = "赵六")
    @ExcelProperty("手机号")
    private String phone;
    @Schema(description = "性别", example = "赵六")
    @ExcelProperty("性别")
    private String teacherSexExport;
    @Schema(description = "科目", example = "赵六")
    @ExcelProperty("科目")
    private String teacherSubjectExport;
    @Schema(description = "教师学段", example = "赵六")
    @ExcelProperty("教师学段")
    private String teacherStageExport;
    @Schema(description = "课补级别", example = "赵六")
    @ExcelProperty("课补级别")
    private Integer supplyLevel;
    @Schema(description = "就职状态", example = "赵六")
    @ExcelProperty("就职状态")
    private String teacherJobStatusExport;
}

image.gif

实体类DO字段:

/**
     * 性别(导出)
     */
    @TableField(exist = false)
    private String teacherSexExport;
    /**
     * 科目(导出)
     */
    @TableField(exist = false)
    private String teacherSubjectExport;
    /**
     * 教师学段(导出)
     */
    @TableField(exist = false)
    private String teacherStageExport;
    /**
     * 就职状态(导出)
     */
    @TableField(exist = false)
    private String teacherJobStatusExport;

image.gif

Service:

/**
     *  教师信息导出
     *
     * @param
     * @return
     */
    PageResult<TeacherManageDO> getTeacherExportData(TeacherManagePageReqVO pageReqVO);

image.gif

ServiceImpl:

//教师信息导出
    @Override
    public PageResult<TeacherManageDO> getTeacherExportData(TeacherManagePageReqVO pageReqVO) {
        PageResult<TeacherManageDO> teacherManageDOPageResult = teacherManageMapper.selectPage(pageReqVO);
        List<TeacherManageDO> list = teacherManageDOPageResult.getList();
        for (TeacherManageDO teacherManageDO : list) {
            if(teacherManageDO.getTeacherSex() == null){
                teacherManageDO.setTeacherSex("");
            }
            else {
                CommonResult<DictDataRespDTO> dictDataRespDTO = dictDataApi.getDictData("system_user_sex", teacherManageDO.getTeacherSex());
                if (dictDataRespDTO != null){
                    teacherManageDO.setTeacherSexExport(dictDataRespDTO.getData().getLabel());
                }
            }
            if(teacherManageDO.getTeacherSubject() == null){
                teacherManageDO.setTeacherSubject("");
            }else{
                String teacherSubject = teacherManageDO.getTeacherSubject();
                teacherSubject = teacherSubject.replace("[", "").replace("]", "");
                String[] parts = teacherSubject.split(", ");
                StringBuilder teacherSubjectNew = new StringBuilder();
                for (int  i = 0; i < parts.length; i++) {
                    CommonResult<DictDataRespDTO> dictDataRespDTO2 = dictDataApi.getDictData("subject", parts[i]);
                    if (dictDataRespDTO2 != null && dictDataRespDTO2.getData() != null) {
                        if (i< parts.length-1){
                            teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel()).append(",");
                        }
                        else {
                            teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel());
                        }
                    }
                }
                // 最后,如果需要移除最后一个逗号,可以检查字符串并移除
                if (teacherSubjectNew.length() > 0 && teacherSubjectNew.charAt(teacherSubjectNew.length() - 1) == ',') {
                    teacherSubjectNew.charAt(teacherSubjectNew.length() - 1); // 移除最后一个逗号
                }
                teacherManageDO.setTeacherSubjectExport(teacherSubjectNew.toString());
            }
            if(teacherManageDO.getTeacherStage() == null){
                teacherManageDO.setTeacherStage("");
            }else{
                CommonResult<DictDataRespDTO> dictDataRespDTO3 = dictDataApi.getDictData("public_teacher_stage", teacherManageDO.getTeacherStage());
                if (dictDataRespDTO3 != null){
                    teacherManageDO.setTeacherStageExport(dictDataRespDTO3.getData().getLabel());
                }
            }
            if(teacherManageDO.getJobStatus() == null){
                teacherManageDO.setJobStatus("");
            }else{
                CommonResult<DictDataRespDTO> dictDataRespDTO4 = dictDataApi.getDictData("hr_status", teacherManageDO.getJobStatus());
                if (dictDataRespDTO4 != null){
                    teacherManageDO.setTeacherJobStatusExport(dictDataRespDTO4.getData().getLabel());
                }
            }
        }
        return teacherManageDOPageResult;
    }

image.gif

Controller:

@GetMapping("/export-excel")
    @Operation(summary = "导出教师管理 Excel")
    @PreAuthorize("@ss.hasPermission('hr:teacher-manage:export')")
    @ApiAccessLog(operateType = EXPORT)
    public void exportTeacherManageExcel(@Valid TeacherManagePageReqVO pageReqVO,
              HttpServletResponse response) throws IOException {
        pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
        List<TeacherManageDO> list = teacherManageService.getTeacherExportData(pageReqVO).getList();
        // 导出 Excel
        ExcelUtils.write(response, "教师管理.xls", "数据", TeacherExportRespVO.class,
                        BeanUtils.toBean(list, TeacherExportRespVO.class));
    }

image.gif

下面我们来拆解一下实现类。

场景:由于业务需求的变化,老师的科目由单个变成了多个,我在存储的时候存储的是数组的字符串,类似于:“[103, 202, 203, 204]”,这就需要去掉左右两侧[]以及拆分成字符串数组再与业务字典进行匹配。

主要就是这句话,让我们来看一下:

if(teacherManageDO.getTeacherSubject() == null){
                teacherManageDO.setTeacherSubject("");
            }else{
                String teacherSubject = teacherManageDO.getTeacherSubject();
                teacherSubject = teacherSubject.replace("[", "").replace("]", "");
                String[] parts = teacherSubject.split(", ");
                StringBuilder teacherSubjectNew = new StringBuilder();
                for (int  i = 0; i < parts.length; i++) {
                    CommonResult<DictDataRespDTO> dictDataRespDTO2 = dictDataApi.getDictData("subject", parts[i]);
                    if (dictDataRespDTO2 != null && dictDataRespDTO2.getData() != null) {
                        if (i< parts.length-1){
                            teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel()).append(",");
                        }
                        else {
                            teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel());
                        }
                    }
                }
                // 最后,如果需要移除最后一个逗号,可以检查字符串并移除
                if (teacherSubjectNew.length() > 0 && teacherSubjectNew.charAt(teacherSubjectNew.length() - 1) == ',') {
                    teacherSubjectNew.charAt(teacherSubjectNew.length() - 1); // 移除最后一个逗号
                }
                teacherManageDO.setTeacherSubjectExport(teacherSubjectNew.toString());
            }

image.gif

if(teacherManageDO.getTeacherSubject() == null){

               teacherManageDO.setTeacherSubject("");

           }

如果科目为空的话就是空字符串插入到excel表里,如果不为空则走else。

String teacherSubject = teacherManageDO.getTeacherSubject();

               teacherSubject = teacherSubject.replace("[", "").replace("]", "");

               String[] parts = teacherSubject.split(", ");

               StringBuilder teacherSubjectNew = new StringBuilder();

这里定义了一个String类型的teacherSubject,为了接收去掉左右括号【】的字符串,又定义了一个Sting类型的数组parts,接收逗号分割以后的teacherSubject字符串,让它变成数组,然后开始for循环遍历。

for (int  i = 0; i < parts.length; i++) {

                   CommonResult<DictDataRespDTO> dictDataRespDTO2 = dictDataApi.getDictData("subject", parts[i]);

                   if (dictDataRespDTO2 != null && dictDataRespDTO2.getData() != null) {

                       if (i< parts.length-1){

                           teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel()).append(",");

                       }

                       else {

                           teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel());

                       }

                   }

               }

(这里最开始我用的增强for循环,但是发现增强for循环不容易去掉最后一个逗号,最后一个逗号依旧会拼接到字符串里,所以又改成了普通for循环)

循环遍历parts里面的每一个值,让这个值去业务字典里找与之对应的唯一的一个label

CommonResult<DictDataRespDTO> dictDataRespDTO2 = dictDataApi.getDictData("subject", parts[i]);

如果这个label不为空,也就是找到的话,就复制给要导出的这个teacherSubjectNew字段

if (dictDataRespDTO2 != null && dictDataRespDTO2.getData() != null) {

                       if (i< parts.length-1){

                           teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel()).append(",");

                       }

这里要注意的是如果到了最后一个元素的时候我们选择走else也就是不在拼接逗号,如果没有到最后一个元素我们就拼接逗号。

if (dictDataRespDTO2 != null && dictDataRespDTO2.getData() != null) {
                        if (i< parts.length-1){
                            teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel()).append(",");
                        }
                        else {
                            teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel());
                        }
                    }

image.gif

最后再赋值给TeacherSubjectExport即可。

teacherManageDO.setTeacherSubjectExport(teacherSubjectNew.toString());

痛点:

在split(", ")的时候一定要注意好这个逗号是有空格的!!!!不能直接split(","),否则后面所有的值都识别不到了,他就会优先识别空格,一定要注意。

teacherSubjectNew.append(dictDataRespDTO2.getData().getLabel()).append(",");


目录
相关文章
|
2月前
|
存储 缓存 Java
Java数组全解析:一维、多维与内存模型
本文深入解析Java数组的内存布局与操作技巧,涵盖一维及多维数组的声明、初始化、内存模型,以及数组常见陷阱和性能优化。通过图文结合的方式帮助开发者彻底理解数组本质,并提供Arrays工具类的实用方法与面试高频问题解析,助你掌握数组核心知识,避免常见错误。
|
21天前
|
Java
Java 数组学习笔记
本文整理Java数组常用操作:遍历、求和、查找、最值及二维数组行求和等典型练习,涵盖静态初始化、元素翻倍、去极值求平均等实例,帮助掌握数组基础与应用。
|
3月前
|
Python
Excel中如何批量重命名工作表与将每个工作表导出到单独Excel文件
本文介绍了如何在Excel中使用VBA批量重命名工作表、根据单元格内容修改颜色,以及将工作表导出为独立文件的方法。同时提供了Python实现导出工作表的代码示例,适用于自动化处理Excel文档。
|
3月前
|
存储 Java 索引
java 数组
在 Java 中,数组是一种数据结构,用于存储多个相同类型的数据元素。数组的大小一旦创建后就不能改变,因此它是固定长度的。Java 数组是一种 对象,即使它存储的值是基本类型(如 int、double 等),它也是一个对象引用。
81 0
|
5月前
|
存储 人工智能 Java
打乱数组内容引发的问题( Java)
本文介绍了两种实现数组随机打乱的方法,并深入探讨了Java中原始数据类型与对象类型的差异。方法一通过自定义随机数交换数组元素位置,方法二借助`Collections.shuffle()`函数完成数组打乱。同时,文章详细解析了`int`和`Integer`的区别,包括声明方式、内存占用、初始化以及对象特性等,并讲解了自动装箱与拆箱的功能,帮助读者更好地理解Java的基础知识。
|
7月前
|
人工智能 Java
Java 中数组Array和列表List的转换
本文介绍了数组与列表之间的相互转换方法,主要包括三部分:1)使用`Collections.addAll()`方法将数组转为列表,适用于引用类型,效率较高;2)通过`new ArrayList&lt;&gt;()`构造器结合`Arrays.asList()`实现类似功能;3)利用JDK8的`Stream`流式计算,支持基本数据类型数组的转换。此外,还详细讲解了列表转数组的方法,如借助`Stream`实现不同类型数组间的转换,并附带代码示例与执行结果,帮助读者深入理解两种数据结构的互转技巧。
376 1
Java 中数组Array和列表List的转换
|
7月前
|
存储 监控 Java
《从头开始学java,一天一个知识点》之:数组入门:一维数组的定义与遍历
**你是否也经历过这些崩溃瞬间?** - 看了三天教程,连`i++`和`++i`的区别都说不清 - 面试时被追问&quot;`a==b`和`equals()`的区别&quot;,大脑突然空白 - 写出的代码总是莫名报NPE,却不知道问题出在哪个运算符 这个系列就是为你打造的Java「速效救心丸」!我们承诺:每天1分钟,地铁通勤、午休间隙即可完成学习;直击痛点,只讲高频考点和实际开发中的「坑位」;拒绝臃肿,没有冗长概念堆砌,每篇都有可运行的代码标本。明日预告:《多维数组与常见操作》。 通过实例讲解数组的核心认知、趣味场景应用、企业级开发规范及优化技巧,帮助你快速掌握Java数组的精髓。
134 23
|
7月前
|
存储 Java 索引
Java 复制数组
本文介绍了Java中数组的基础知识与常用操作,包括数组的概念、创建、访问元素、遍历、复制、排序和搜索等方法。同时详细讲解了数组的五种赋值方式,并通过代码示例演示了求总和平均值、最大最小值、升序降序排序及Arrays类的常用方法。内容深入浅出,适合初学者学习掌握Java数组的核心功能与应用场景。
|
6月前
|
存储 Java 数据挖掘
Java 中数组的多种定义方式
本文深入解析了Java中数组的多种定义方式,涵盖基础的`new`关键字创建、直接初始化、动态初始化,到多维数组、`Arrays.fill()`方法以及集合类转换为数组等高级用法。通过理论与实践结合的方式,探讨了每种定义方法的适用场景、优缺点及其背后的原理,帮助开发者掌握高效、灵活的数组操作技巧,从而编写更优质的Java代码。
219 0

热门文章

最新文章