java list 转换树形结构 支持模糊搜索



import org.springframework.beans.BeanUtils;

import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
 * @ClassName TreeUtil
 * @Description 树状图列表转换
 * @Author LD
 * @DATE 2021/4/15 18:16
 * @Version 1.0
 */


public class TreeUtil {

    /**
     * @Description: 首字母转大写
     */
    public static String firstCharToUpperCase (String str) {
        if (str == null) {
            return null;
        }
        if ("".equals(str)) {
            return "";
        }
        char[] cs = str.toCharArray();
        cs[0] -= 32;
        return String.valueOf(cs);
    }


    /**
     * 调用示例:示例: List<TreeNode> head = toTree(TreeNode.class,nodeList,"id","parentId","children",0L);
     *
     * @param clazz         类.class
     * @param dataList      数据列表
     * @param idField       ID字段名称
     * @param parentIdField 父节点ID字段名称
     * @param childrenField 孩子字段名称
     * @param rootFlag      如果某个节点的ParentId等于rootFlag,即改节点为根节点
     * @Description: List转Tree
     */
    public static <T> List<T> toTree (Class<T> clazz, List<T> dataList, String idField, String parentIdField, String childrenField, Object rootFlag) throws Exception {
        List<T> treeList = new ArrayList<>();
        Map<Object, T> map = new HashMap<>();
        Map<Object, Boolean> flag = new HashMap<>();
        String getIdStr = "get" + firstCharToUpperCase(idField);
        String getParentIdStr = "get" + firstCharToUpperCase(parentIdField);
        String getChildrenStr = "get" + firstCharToUpperCase(childrenField);
        String setChildrenStr = "set" + firstCharToUpperCase(childrenField);
        Method getIdMethod = null;
        Method getParentIdMethod = null;
        Method getChildrenMethod = null;
        Method setChildrenMethod = null;
        try {
            getIdMethod = clazz.getDeclaredMethod(getIdStr);
            getParentIdMethod = clazz.getDeclaredMethod(getParentIdStr);
            getChildrenMethod = clazz.getDeclaredMethod(getChildrenStr);
            setChildrenMethod = clazz.getDeclaredMethod(setChildrenStr, List.class);
        } catch (Exception e) {
            e.printStackTrace();
            throw new RuntimeException("转树形结构-通过反射获取方法错误!", e);
        }


        for (T node : dataList) {
            map.put(getIdMethod.invoke(node), node);
            Object parentIdTmp = getParentIdMethod.invoke(node);
            if (rootFlag == null || "".equals(rootFlag)) {
                if (parentIdTmp == null || "".equals(parentIdTmp)) {
                    treeList.add(node);
                }
            } else {
                if (String.valueOf(rootFlag).equals(String.valueOf(parentIdTmp))) {
                    treeList.add(node);
                }
            }
        }
        for (T node : dataList) {
            T parentNode = map.get(getParentIdMethod.invoke(node));
            if (parentNode != null) {
                List<T> invoke = (List<T>) getChildrenMethod.invoke(parentNode);
                if (invoke == null) {
                    invoke = new ArrayList<>();
                    setChildrenMethod.invoke(parentNode, invoke);
                }
                invoke.add(node);

            }
        }
        return treeList;
    }
    /**
     * 调用示例:示例: List<TreeNode> head = toTree(TreeNode.class,nodeList,"id","parentId","children","name",0L,"name");
     *
     * @param clazz         类.class
     * @param dataList      数据列表
     * @param idField       ID字段名称
     * @param parentIdField 父节点ID字段名称
     * @param childrenField 孩子字段名称
     * @param searchField   模糊查询的字段
     * @param text          模糊查询值
     * @param <T>
     * @return
     * @throws Exception
     * @Description: List转Tree
     */
    public static <T> List<T> toTree (Class<T> clazz, List<T> dataList, String idField, String parentIdField, String childrenField, String searchField, Object rootFlag, String text) throws Exception {
        List<T> treeList = new ArrayList<>();
        Map<Object, T> map = new HashMap<>();
        Map<Object, Boolean> flag = new HashMap<>();
        String getIdStr = "get" + firstCharToUpperCase(idField);
        String getParentIdStr = "get" + firstCharToUpperCase(parentIdField);
        String getChildrenStr = "get" + firstCharToUpperCase(childrenField);
        String setChildrenStr = "set" + firstCharToUpperCase(childrenField);
        String getSearchStr = "get" + firstCharToUpperCase(searchField);
        Method getIdMethod = null;
        Method getParentIdMethod = null;
        Method getChildrenMethod = null;
        Method getSearchMethod = null;
        Method setChildrenMethod = null;
        try {
            getIdMethod = clazz.getDeclaredMethod(getIdStr);
            getParentIdMethod = clazz.getDeclaredMethod(getParentIdStr);
            getChildrenMethod = clazz.getDeclaredMethod(getChildrenStr);
            setChildrenMethod = clazz.getDeclaredMethod(setChildrenStr, List.class);
        } catch (Exception e) {
            e.printStackTrace();
            throw new RuntimeException("转树形结构-通过反射获取方法错误!", e);
        }


        for (T node : dataList) {
            map.put(getIdMethod.invoke(node), node);
            Object parentIdTmp = getParentIdMethod.invoke(node);
            if (rootFlag == null || "".equals(rootFlag)) {
                if (parentIdTmp == null || "".equals(parentIdTmp)) {
                    treeList.add(node);
                }
            } else {
                if (String.valueOf(rootFlag).equals(String.valueOf(parentIdTmp))) {
                    treeList.add(node);
                }
            }
        }
        for (T node : dataList) {
            T parentNode = map.get(getParentIdMethod.invoke(node));
            if (parentNode != null) {
                List<T> invoke = (List<T>) getChildrenMethod.invoke(parentNode);
                if (invoke == null) {
                    invoke = new ArrayList<>();
                    setChildrenMethod.invoke(parentNode, invoke);
                }
                invoke.add(node);

            }
        }
        return search(clazz, childrenField, searchField, treeList, text);
    }
     /**
     * 模糊搜索
     *
     * @param clazz
     * @param childrenField
     * @param searchField
     * @param data
     * @param text
     * @param <T>
     * @return
     * @throws Exception
     */
    public static <T> List<T> search (Class<T> clazz, String childrenField, String searchField, List<T> data, String text) throws Exception {
        if (StringUtil.isBlank(text)) {
            return data;
        }
        Map<Object, T> map = new HashMap<>();
        Map<Object, Boolean> flag = new HashMap<>();
        String getChildrenStr = "get" + firstCharToUpperCase(childrenField);
        String setChildrenStr = "set" + firstCharToUpperCase(childrenField);
        String getSearchStr = "get" + firstCharToUpperCase(searchField);
        Method getChildrenMethod = null;
        Method getSearchMethod = null;
        Method setChildrenMethod = null;
        try {
            getChildrenMethod = clazz.getDeclaredMethod(getChildrenStr);
            getSearchMethod = clazz.getDeclaredMethod(getSearchStr);
            setChildrenMethod = clazz.getDeclaredMethod(setChildrenStr, List.class);
        } catch (Exception e) {
            e.printStackTrace();
            throw new RuntimeException("转树形结构-通过反射获取方法错误!", e);
        }
        List<T> res = new ArrayList<>();
        for (T treeNode : data) {
            List<T> children = (List<T>) getChildrenMethod.invoke(treeNode);
            if (children != null && children.size() > 0) {
                List<T> searchData = search(clazz, childrenField, searchField, children, text);
                T tn = clazz.newInstance();
                BeanUtils.copyProperties(treeNode, tn);
                setChildrenMethod.invoke(tn, searchData);

                if (getSearchMethod.invoke(treeNode).toString().contains(text) || searchData.size() > 0) {
                    res.add(tn);
                }
            } else {
                if (getSearchMethod.invoke(treeNode).toString().contains(text)) {
                    res.add(treeNode);
                }
            }
        }
        return res;
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的Java代码示例,演示如何实现树形结构模糊搜索: ```java public class TreeNode { private String value; private List<TreeNode> children; // 构造函数 public TreeNode(String value) { this.value = value; this.children = new ArrayList<TreeNode>(); } // 添加子节点 public void addChild(TreeNode child) { this.children.add(child); } // 模糊搜索 public List<TreeNode> fuzzySearch(String keyword) { List<TreeNode> result = new ArrayList<TreeNode>(); if (this.value.contains(keyword)) { result.add(this); } for (TreeNode child : this.children) { result.addAll(child.fuzzySearch(keyword)); } return result; } } ``` 在上述代码中,`TreeNode`类表示树的节点,包括值和子节点列表两个属性。其中,`addChild`方法用于添加子节点,`fuzzySearch`方法实现了模糊搜索功能。具体实现中,首先判断当前节点的值是否包含关键字,如果是则将该节点加入到搜索结果集中;然后对子节点进行递归搜索,并将搜索结果添加到结果集中;最后返回结果集。 使用时,可以先构建一棵树,然后调用根节点的`fuzzySearch`方法进行搜索,例如: ```java // 构建树 TreeNode root = new TreeNode("root"); root.addChild(new TreeNode("node1")); root.addChild(new TreeNode("node2")); root.children.get(0).addChild(new TreeNode("node11")); root.children.get(0).addChild(new TreeNode("node12")); root.children.get(1).addChild(new TreeNode("node21")); root.children.get(1).addChild(new TreeNode("node22")); // 模糊搜索 List<TreeNode> result = root.fuzzySearch("1"); System.out.println(result); ``` 上述代码中,首先构建了一棵树,然后搜索其中值包含关键字“1”的节点,并将搜索结果打印出来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值