hierarchy-utils 通用树形数据工具库

2024-04-15 15:12

本文主要是介绍hierarchy-utils 通用树形数据工具库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通用树形数据工具库

  • hierarchy-utils
    • 链接地址
    • 使用示例
      • 数据结构 - 菜单
      • 数据源
      • 1.通过原数据结构返回树形数据
      • 2.通过转换数据结构(Map / JSONObject)返回树形数据
      • 3.返回源数据列表中id为rootId的元素或pid为rootId且id能整除2的全部子元素的数据列表 (支持将树形数据打平及过滤)
      • 4.怎样对指定的返回结果列表进行排序的方法

hierarchy-utils

用于构建/查找具有层级关系树形数据的工具库,以解决业务中常见的树形数据处理需求
支持自定义过滤数据、排序及转换数据等

链接地址

https://github.com/joker-pper/hierarchy-utils

使用示例

数据结构 - 菜单

@Data
public class Menu {private Integer id;private String name;private Integer pid;private Integer sort;private List<Menu> children;
}

数据源

    //查询当前用户的菜单列表List<Menu> menuList = menuService.findAllByUserId();//通过json转换List<Menu> menuList = JSONObject.parseArray(menuText, Menu.class);;

1.通过原数据结构返回树形数据

       //默认根元素为-1 (当前所有一级菜单的pid为-1,可根据实际定义根元素使用)Integer rootId = -1;//排序(需注意业务属性值是否为空),可选Comparator<Menu> comparator = Comparator.comparingInt(Menu::getSort);HierarchyUtils.HierarchyFunctions<Menu, Integer, Menu> defaultFunctions = new HierarchyUtils.HierarchyFunctions<>();//获取piddefaultFunctions.setGetPidFunction(data -> data.getPid());//获取iddefaultFunctions.setGetIdFunction(data -> data.getId());//验证是否为rootdefaultFunctions.setIsRootFunction(id -> Objects.equals(rootId, id));//设置childrendefaultFunctions.setSetChildrenFunction((parent, children) -> {parent.setChildren(children);});//是否返回root元素(未设置时默认false,开启时root元素必须存在)defaultFunctions.setIsWithRoot(() -> false);//过滤条件(可选,用来筛选数据)defaultFunctions.setFilterPredicate(menu -> true);List<Menu> hierarchyResult = HierarchyUtils.getHierarchyResult(menuList,defaultFunctions,comparator);System.out.println(JSONObject.toJSONString(hierarchyResult));

2.通过转换数据结构(Map / JSONObject)返回树形数据

    //默认根元素为-1 (当前所有一级菜单的pid为-1,可根据实际定义根元素使用)Integer rootId = -1;//排序(需注意业务属性值是否为空),可选Comparator<Menu> comparator = Comparator.comparingInt(Menu::getSort);HierarchyUtils.HierarchyFunctions<Menu, Integer, JSONObject> transferFunctions = new HierarchyUtils.HierarchyFunctions<>();//获取pidtransferFunctions.setGetPidFunction(data -> data.getPid());//获取idtransferFunctions.setGetIdFunction(data -> data.getId());//验证是否为roottransferFunctions.setIsRootFunction(id -> Objects.equals(rootId, id));//设置转换函数transferFunctions.setTransferFunction(menu -> {//转换数据JSONObject result = (JSONObject) JSON.toJSON(menu);//可定义或移除属性result.put("title", menu.getName());result.put("order", menu.getSort());result.put("newName", menu.getName());result.remove("name");return result;});//设置childrentransferFunctions.setSetChildrenFunction((parent, children) -> {parent.put("children", children);});//是否返回root元素(未设置时默认false,开启时root元素必须存在)transferFunctions.setIsWithRoot(() -> false);//过滤条件(可选,用来筛选数据)transferFunctions.setFilterPredicate(menu -> true);List<JSONObject> transferResults = HierarchyUtils.getHierarchyResult(menuList,transferFunctions,comparator);System.out.println(JSONObject.toJSONString(transferResults));

3.返回源数据列表中id为rootId的元素或pid为rootId且id能整除2的全部子元素的数据列表 (支持将树形数据打平及过滤)

Integer rootId = 1;HierarchyFlatUtils.HierarchyFlatFunctions<Menu, Integer, Menu> functions = new HierarchyFlatUtils.HierarchyFlatFunctions<>();//获取pidfunctions.setGetPidFunction(data -> data.getPid());//获取idfunctions.setGetIdFunction(data -> data.getId());//验证是否为rootfunctions.setIsRootFunction(id -> Objects.equals(rootId, id));//是否返回root元素(未设置时默认false,开启时root元素必须存在)functions.setIsWithRoot(() -> true);//是否返回全部的子元素(未设置时默认false,即默认只返回root元素的直接子元素)functions.setIsWithAllChildren(() -> true);//过滤条件(可选,用来筛选数据)functions.setFilterPredicate(menu -> menu.getId() % 2 == 0 || Objects.equals(rootId, menu.getId()));//排序(需注意业务属性值是否为空),可选Comparator<Menu> comparator = Comparator.comparingInt(Menu::getSort);List<Menu> matchResults = HierarchyFlatUtils.getHierarchyFlatResult(menuList,functions,comparator);//对返回结果排序(需注意业务属性值是否为空),可选HierarchySortUtils.sort(matchResults, comparator);System.out.println(JSONObject.toJSONString(matchResults));

4.怎样对指定的返回结果列表进行排序的方法

    //对返回结果排序 (只排序当前列表,不会递归排序子元素)HierarchySortUtils.sort(list, comparator); //对返回结果及子元素排序(递归排序)HierarchySortUtils.sortWithChildren(list, childrenFunction, comparator);  

这篇关于hierarchy-utils 通用树形数据工具库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/906169

相关文章

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查