我得到了从数据库中提取的数据,我想将其转换为树。
数据:
妈妈 儿子 momText sonText 1 2 主层1 2 4 级别 1 级别 2 4 5 2 级 3 级 4 7 2 级 3 级 1 8 主层1 8 9 1 级 2 级
代码:
List<String[]> testList=new ArrayList<String[]>();;
String[] test1={"1","2","Main","Level1"};
String[] test2={"2","4","Level1","Level2"};
String[] test3={"4","5","Level2","Level3"};
String[] test4={"4","7","Level2","Level3"};
String[] test5={"1","8","Main","Level1"};
String[] test6={"8","9","Level1","Level2"};
testList.add(test1);
testList.add(test2);
testList.add(test3);
testList.add(test4);
testList.add(test5);
testList.add(test6);
HashMap<String, List<String[]>> myHashMap = new HashMap<String, List<String[]>>();
for(int i=0; i<testList.size(); i++){
String[] test=testList.get(i);
String parent=test[0];
List<String[]> children = myHashMap.get(parent);
if (children == null){
children = new ArrayList<String[]>();
myHashMap.put(parent,children);
}
children.add(test);
}
Tree myTree=new Tree();
String node=testList.get(0)[0];
printTree(node, myTree, myHashMap);
我还有一个叫做“printTree”的方法
public void printTree(String node, Tree myTree, HashMap<String, List<String[]>> myHashMap){
CheckBox nodeCheckBox=new CheckBox(node);
TreeItem root = new TreeItem(nodeCheckBox);
myTree.addItem(root);
if(myHashMap.containsKey(node)){
List<String[]> testList=myHashMap.get(node);
for(int i=0; i<testList.size(); i++){
String nextNode=testList.get(i)[1];
printTree(nextNode, myTree, myHashMap);
}
}
}
运行后,输出如下所示,这是不正确的:
我希望结果如下所示:
我相信我们需要在 printTree 函数中进行一些更改才能使其正常工作。
注1:如果您不喜欢我的编码方式,您可以随意提供自己的解决方案,但请使用此对象中的数据List<String[]> testList
。
注意2:你不需要担心文本(momText & sonText)列,只需尝试操作数字(mon&son)列,文本可以通过字符串数组轻松访问。