如何通过delphi,virtualstringtree中的文件名列表构建层次结构

时间:2013-06-30 18:48:08

标签: delphi virtualtreeview tvirtualstringtree

我一直坚持这个问题。

我有一个归档文件名列表(这里是文件和文件夹)。此列表如下所示:

folder
folder/index.html
otherfolder

问题是将层次结构设置为virtualstringtree。 属于的文件和文件夹将是根文件夹中的子节点。

有什么想法吗?

1 个答案:

答案 0 :(得分:2)

这是完整的代码。 你读行,你拆分这一行来获取每个子文件夹。 如果每个子文件夹已在树中,则搜索每个子文件夹,否则创建新的子文件夹。 经典树视图测试:)

procedure TForm1.Analyze(ListOfFiles : TStringList);
var
   root: TTreeNode;
   nI: Integer;
   files : TStringList;
  nJ: Integer;
begin
   for nI := 0 to ListOfFiles.Count - 1 do
   begin
        files := TStringList.Create;
        files.Delimiter := '/';
        files.DelimitedText := ListOfFiles[nI];
        root := nil;
        for nJ := 0 to files.Count - 1 do
             root := GetFolder(root, files[nJ])

        FreeAndNil( Files );
   end;
end;

function TForm1.GetFolder( TreeNode : TTreeNode; SubFolder : String ) : TTreeNode;
var
  nI: Integer;
begin
     result := nil;

     if Assigned( TreeNode ) then
     begin
         for nI := 0 to TreeNode.Count - 1 do
         begin
              if SameText(TreeNode.Item[nI].Text, SubFolder) then
              begin
                 result := TreeNode.item[nI];
                 Exit;
              end;
         end;
     end
     else
     begin
         for nI := 0 to TreeView1.Items.Count - 1 do
         begin
              if SameText(TreeView1.Items[nI].Text, SubFolder) then
              begin
                 result := TreeView1.Items[nI];
                 Exit;
              end;
         end;

     end;
     if not Assigned( result ) then
     begin
          result := TreeView1.Items.AddChild( TreeNode, SubFolder );
          Exit;
     end;

end;