方法一代码:

path = './a/b/c/d/e/f';
$path_arr = explode('/',$path);//得到数组array('.','a','b','c','d','e','f');
for($i=0;$i<count($path_arr);$i++){
static $dir;//只初始化一次,保留上次调用的值
$dir .= $path_arr[$i].'/';//i=0 ./ i=1 ./a i=2 ./a/b .....
//echo $dir,'<br/>';
if(!is_dir($dir)){//过滤下 如果已经是目录就不创建 比如 ./
echo mkdir($dir)?'ok<br/>':'fail<br/>';//创建
}
}

方法二代码:

 function mk_dir($dir){

               //$dir_arr  = array();//定义一个空数组用来存放路径  可以把它想象成为一个工作单

               while(!is_dir($dir)){ //如果$dir不是目录  那么就表示这个工作还没做 因此就放入工作单里

         array_push($dir_arr,$dir);

        $dir = dirname($dir);//取得上级目录在赋值给$dir 

      }

              //上面是把新工作(不是目录的)存入到数组

           while(count($dir_arr)){

            $list = array_pop($dir_arr);

                                      mkdir($list);

      }

    //通过出栈 来层层创建目录

}

$path ='./a/b/c/d';

mk_dir($path);

模拟过程:

$dir = './a/b/c/d';

$dir 不是目录,进入循环

$dir_arr =array('./a/b/c/d');

$dir = dirname($dir)='./a/b/c';

$dir 不是目录,进入循环

$dir_arr =array('./a/b/c/d','./a/b/c');

    $dir = dirname($dir)='./a/b';

    $dir 不是目录,进入循环

    $dir_arr =array('./a/b/c/d','./a/b/c','./a/b');

$dir = dirname($dir)='./a';

    $dir 不是目录,进入循环

    $dir_arr =array('./a/b/c/d','./a/b/c','./a/b','./a');

$dir = dirname($dir)='./';

  $dir 是目录,退出循环

------------------------------------------------

<退出循环后的数组>array('./a/b/c/d','./a/b/c','./a/b','./a');

进入 出栈循环

count($dir_arr) =4  进入循环

$list = array_pop($dir_arr) = './a';

mkdir($list);//a目录创建

count($dir_arr) =3  进入循环

$list = array_pop($dir_arr) = './a/b';

mkdir($list);//a/b目录创建

count($dir_arr) =2  进入循环

$list = array_pop($dir_arr) = './a/b/c';

mkdir($list);//a/b/c目录创建

count($dir_arr) =1  进入循环

$list = array_pop($dir_arr) = './a/b/c/d';

mkdir($list);//a/b/c/d目录创建

count($dir_arr) =0  退出循环

----------------------------------------

总结:递归换成迭代的 要 借助栈的思想或者static

级联创建目录的思想 还是想必须把上级目录创建成功

php-迭代创建级联目录的更多相关文章

  1. php-递归创建级联目录

    方法一: function mk_dir($path_arr,$root){ if(!empty($path_arr)){ static $path;//每次保存上次调用的值 $path .= '/' ...

  2. 利用php函数mkdir递归创建层级目录

    项目开发中免不了要在服务器上创建文件夹,比如上传图片时的目录,模板解析时的目录等.这不当前手下的项目就用到了这个,于是总结了几个循环创建层级目录的方法. php默认的mkdir一次只能创建一层目录,而 ...

  3. MFC 创建多层目录

    创建多层目录 BOOL CTestToolCtr::CreateFolder(CString strNewFolder) { /************************************ ...

  4. php使用递归创建多级目录

    <?php header('Content-type:text/html;charset=utf8'); echo "Loading time:".date('Y-m-d H ...

  5. PHP判断文件夹是否存在和创建文件夹的方法(递归创建多级目录)

    在开始之前,我先说明一下,可能许多朋友与我一样认为只要给一个路径,mkdir就可以创建文件夹,其实不是那样,单个的MKDIR只能创建一级目录,对于多级的就不行了,那如何用mkdir来创建呢?先我抄一段 ...

  6. PHP 检查并创建多级目录

    <?php //检查并创建多级目录    function checkDir($path){        $pathArray = explode('/',$path);        $no ...

  7. VS 创建虚拟目录失败,映射到其他文件夹!

    今天,改一哥们项目!立马,问了一下原因.支支吾吾的气死LZ! 算了,就不信自己琢磨不出来!哼 找了半天,坑爹的是在Web.csproj文件中! 用txt打开,发现这个东东! <UseIIS> ...

  8. php创建多级目录的两种方法

    1.使用递归的思想 function mkdirs_2($path){ if(!is_dir($path)){ mkdirs_2(dirname($path)); if(!mkdir($path, 0 ...

  9. PHP递归创建多级目录(一道面试题的解题过程)

    今天看到一道面试题,要写出一个可以创建多级目录的函数: 我的第一个感觉就是用递归创建,具体思路如下: function Directory($dir){ if(is_dir($dir) || @mkd ...

随机推荐

  1. Spring Boot 的Maven多模块开发web项目使用外部容器进行部署

    Spring Boot中自带有Tomcat容器,因此Spring Boot项目只需要运行main函数,就可以运行,但是以往的web项目,我们习惯于使用自己安装的Tomcat运行或者使用Tomcat.J ...

  2. iOS 多线程之线程锁Swift-Demo示例总结

    线程锁是什么 在前面的文章中总结过多线程,总结了多线程之后,线程锁也是必须要好好总结的东西,这篇文章构思的时候可能写的东西得许多,只能挤时间一点点的慢慢的总结了,知道了线程之后要了解线程锁就得先了解一 ...

  3. Ipad弹出UIAlertControllerStyleActionSheet时发生崩溃

    pad弹出UIAlertControllerStyleActionSheet时,在iphone上运行正常,但在ipad上崩溃,解决代码如下: UIAlertController *alertVc = ...

  4. Azure IoT Edge on Windows 10 IoT Core

    在今年的Build大会上,微软推出了Azure IoT Edge的第一个版本(https://github.com/Azure/iot-edge ).该版本的主要特点就是将计算能力由Azure端推送至 ...

  5. jdk1.8hashmap源码解析

    /* * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETA ...

  6. Swift Runtime ?

    你肯定也想过 在OC中相信每一个iOS开发都知道Runtime, 现在Swift也更新到4.0版本了,要是你也学习过Swift的话你可能也会想过这样一个问题,OC大家都是到是有动态性的,你能通过run ...

  7. 15. 使用Apache Curator管理ZooKeeper

    Apache ZooKeeper是为了帮助解决复杂问题的软件工具,它可以帮助用户从复杂的实现中解救出来. 然而,ZooKeeper只暴露了原语,这取决于用户如何使用这些原语来解决应用程序中的协调问题. ...

  8. CCF-201512-1-数位之和

    问题描述 试题编号: 201512-1 试题名称: 数位之和 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 给定一个十进制整数n,输出n的各位数字之和. 输入格式 输入一个整 ...

  9. mongo安装,及远程连接

    yum 安装mongo创建镜像 1 vi /etc/yum.repos.d/mongodb-org-3.6.repo添加一下路径 保存退出[mongodb-org-3.6]name=MongoDB R ...

  10. oracle中 merge into 的用法

    很多时候我们需要通过筛选条件同时对表进行 更新,插入,删除 等操作.这样如果我们单一的去操作表会显得很麻烦,下面会说到这个merge  into 的用法会极大的优化我们操作表的时间和代码量. 举例,先 ...