JS 文件名字路径数组递归归类成文件树 流程图

65 篇文章 6 订阅
61 篇文章 2 订阅

 

 

数据: [ZZDS - 副本\tool\fonts\etc\,$Extend\,x64 - 副本\zh-Hans\aaaaaa\,
x64 - 副本\1028\aaaaaaa\,x64 - 副本\1028\aaaaaaa\bbbbbbbbbbb\,
x64 - 副本\1028\aaaaaaa\bbbbbbbbbbb\zh-Hant\,a1\,a1\a2\,a1\a2\a3\,a1\a2\a3\a4\,
a1 - 副本\,a1 - 副本\a2\,a1 - 副本\a2\a3\,a1 - 副本\a2\a3\a4\]

 

 

var g_rootData=[];  全局变量  先拿到一个根目录里面的第一个数据:

    g_rootData =  {
            sName:H:\,
            sChild:[]
    };

 

    for(var i = 0;i<param.length;i++) 
    {
        
        InsertIntoTree(param[i],g_rootData);循环里面调用

    }

function InsertIntoTree(param,node) //递归遍历
{
    stdout.println("param: "+param+" ,node: "+node.sName);
    var iFind = param.indexOf('\\');
    stdout.println("iFind = "+iFind);
    var vName = param;
    var vPath = "";
    if(iFind>0)
    {
        vPath = param;
        vName = vName.splice(iFind,vName.length);
        vPath = vPath.splice(0,iFind+1);
    }
    stdout.println("iFind: "+iFind+" ,vName: "+vName+" ,path: "+vPath);
    var vChild;
    vChild = 
    {
        sName:vName,
        sChild:[]
    }
    node.sChild.push(vChild);
    if(vPath.length)
    {
        InsertIntoTree(vPath,vChild);
    }
}

function printTree(node ,path)   //输出打印
{
    stdout.println("path: "+path+" ,name:"+node.sName);
    var i;
    var vNextPath  = node.sName;
    if(path.length)
    {
        vNextPath = path +"\\"+ node.sName;
    }
    
    for(i=0;i<node.sChild.length;i++)
    {
        printTree(node.sChild[i],vNextPath);
    }
}

结果:

path: H:\ ,name:a1
path: H:\ ,name:a1
path: H:\\a1 ,name:a2
path: H:\ ,name:a1
path: H:\\a1 ,name:a2
path: H:\\a1\a2 ,name:a3
path: H:\ ,name:a1
path: H:\\a1 ,name:a2
path: H:\\a1\a2 ,name:a3
path: H:\\a1\a2\a3 ,name:a4
path: H:\ ,name:a1 - 副本
path: H:\ ,name:a1 - 副本
path: H:\\a1 - 副本 ,name:a2
path: H:\ ,name:a1 - 副本
path: H:\\a1 - 副本 ,name:a2
path: H:\\a1 - 副本\a2 ,name:a3
path: H:\ ,name:a1 - 副本
path: H:\\a1 - 副本 ,name:a2
path: H:\\a1 - 副本\a2 ,name:a3
path: H:\\a1 - 副本\a2\a3 ,name:a4

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值