当前位置: 首页 > article >正文

java循环遍历树状结构对象并转换成另外树状结构对象

项目工程需要调用外部服务接口返回树状结构对象,不能直接使用,需要再次转换处理,满足实际的项目需求,涉及到两点处理:
1、遍历树状对象

//外部服务对象
public class DepartmentVO {

    private Integer id;
    private Integer orgId;
    private String code;
    private String name;
    private String nameZh;
    private Integer parentId;
    private String parentIds;
    private DepartmentStatus status;
    private DepartmentType type;
    private Integer ownerId;
    private Integer rank;
//    private Instant createdAt;
//    private Instant updatedAt;
    private Integer createdBy;
    private Integer updatedBy;
    private String userCode;
    private String username;
    private List<DepartmentVO> subDepartments;

}


//需要使用的树状结构对象
public class McmpDepartmentDto implements Serializable {

  @ApiModelProperty(value = "部门ID", example = "0")
  private Integer id;
  @ApiModelProperty(value = "租户ID", example = "0")
  private Integer orgId;
  @ApiModelProperty(value = "部门编码")
  private String code;
  @ApiModelProperty(value = "部门英文名称")
  private String name;
  @ApiModelProperty(value = "部门中文名称")
  private String nameZh;
  @ApiModelProperty(value = "父级ID")
  private Integer parentId;
  @ApiModelProperty(value = "父级(路径)")
  private String parentIds;
  @ApiModelProperty(value = "级别(1,2,3,4....)")
  private String level;
  private List<McmpDepartmentDto> subDepartments = new ArrayList<>();
  public void addChild(McmpDepartmentDto child) {
    subDepartments.add(child);
  }

  /**
   * 查找指定ID的节点,并返回该节点及其所有子节点的ID集合
   * @param root 树的根节点
   * @param targetId 目标节点的ID
   * @return 包含目标节点及其所有子节点ID的集合
   */
  public static Set<Integer> findNodeAndDescendants(DepartmentVO root, Integer targetId) {
    Set<Integer> ids = new HashSet<>();
    searchNodeAndCollectIds(root, targetId, ids);
    return ids;
  }

  private static void searchNodeAndCollectIds(DepartmentVO node, Integer targetId, Set<Integer> ids) {
    if (node.getId().equals(targetId)) {
      ids.add(node.getId());
      collectChildIds(node, ids);
    } else {
      for (DepartmentVO child : node.getSubDepartments()) {
        searchNodeAndCollectIds(child, targetId, ids);
      }
    }
  }

  private static void collectChildIds(DepartmentVO node, Set<Integer> ids) {
    ids.add(node.getId());
    for (DepartmentVO child : node.getSubDepartments()) {
      collectChildIds(child, ids);
    }
  }

//调用地方
public List<McmpDepartmentDto> searchDepartmentTree(Long tenantId){
        List<McmpDepartmentDto> mcmpDepartmentDtos = new ArrayList<>();
        DepartmentSearchForm departmentSearchForm = new DepartmentSearchForm();
        departmentSearchForm.setOrgId(tenantId.intValue());
        //外部服务返回的集合对象,里面对象就是树状结构
        List<DepartmentVO> result =  iamDepartmentClient.searchTree(departmentSearchForm).getData();
        if(!CollectionUtils.isEmpty(result)){
            for(DepartmentVO departmentVO :result){
                mcmpDepartmentDtos.add(traverseTreeRecursive(departmentVO));
            }
        }
        return mcmpDepartmentDtos;
    }


    public McmpDepartmentDto traverseTreeRecursive(DepartmentVO departmentVO) {

        if (departmentVO == null) {
            return null;
        }
        McmpDepartmentDto mcmpDepartmentDto = new McmpDepartmentDto();
        BeanUtils.copyProperties(departmentVO,mcmpDepartmentDto);
        mcmpDepartmentDto.setLevel(getLevel(mcmpDepartmentDto.getParentIds()));
        // 遍历子节点
        for (DepartmentVO child : departmentVO.getSubDepartments()) {
            mcmpDepartmentDto.addChild(traverseTreeRecursive(child));
        }
        return mcmpDepartmentDto;
    }

    /**
     * 通过当前所属父级的路径信息,返回当前节点所属于的Level层级
     * @param parentIds
     * 举例:最顶级阶段 parentIds=null 表示一级; parentIds=/34959/ 表示二级 ; parentIds=/34959/35079/ 表示三级,
     * @return
     */
    public String getLevel(String parentIds){
        if(null==parentIds || parentIds.equals("")){
            return "1";
        }
        return String.valueOf(countCharUsingRegex(parentIds,"/"));
    }

    /**
     * 字符串中出现某个特殊符号的次数
     * @param str
     * @param regex
     * @return
     */
    public static int countCharUsingRegex(String str, String regex) {
        Pattern pattern = Pattern.compile(regex);
        Matcher matcher = pattern.matcher(str);
        int count = 0;
        while (matcher.find()) {
            count++;
        }
        return count;
    }

http://www.kler.cn/news/309756.html

相关文章:

  • 6.安卓逆向-安卓开发基础adb工具
  • 学习贵在善假于物
  • 什么是科技与艺术相结合的异形创意圆形(饼/盘)LED显示屏
  • YooAsset基础操作及热更
  • 自监督的主要学习方法
  • Web植物管理系统-下位机部分
  • Facebook主页,广告账户,BM被封分别怎么解决?
  • sicp每日一题[2.17]
  • Ubuntu上如何使用sh文件更新CMake
  • 【二十一】【QT开发应用】ListWiddget图标模式
  • yolo自动化项目实例解析(二)ui页面整理
  • 组件上的v-model(数据传递),props验证,自定义事件,计算属性
  • 家电制造的隐形守护者:矫平机确保材料完美无瑕
  • Linux 调用write()函数后,内核一般多久将数据写入磁盘
  • Java轻量级测试框架的实现与使用 总篇
  • 【资料分析】刷题日记1
  • 保护您的企业免受网络犯罪分子侵害的四个技巧
  • 【运维监控】Prometheus+grafana监控flink运行情况
  • SpringBoot2:web开发常用功能实现及原理解析-@ControllerAdvice实现全局异常统一处理
  • [苍穹外卖]-10WebSocket入门与实战
  • SpringBoot整合WebSocket实现消息推送或聊天功能示例
  • 从头开始学MyBatis—02基于xml和注解分别实现的增删改查
  • (java+Seleniums3)自动化测试实战2
  • ssh远程连接try1账号切换tips
  • 宝兰德MCP系列介绍 ①:中间件管理能力全线升级,驱动企业数字化管理效能提升
  • node.js 完全卸载和下载配置
  • 五种数据库特性对比(Redis/Mysql/SQLite/ES/MongoDB)
  • 780nm 扫地机器人模组:科技引领智能清洁新潮流
  • windows使用tcpdump.exe工具进行抓包教程
  • 企业如何构建有效的数据泄露防护安全体系