方法一代码:

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. 2746:约瑟夫问题poj

    2746:约瑟夫问题 总时间限制:  1000ms 内存限制:  65536kB 描述 约瑟夫问题:有n只猴子,按顺时针方向围成一圈选大王(编号从1到n),从第1号开始报数,一直数到m,数到m的猴子退 ...

  2. 在azure中建立DDC集群

    在Azure上建立DDC集群 建立3台虚拟机作为UCP集群,3台虚拟机作为DTR集群. 资源组:HYD-DockerDateCenter 虚拟机size:DS3 4核14G 系统:ubuntu14.0 ...

  3. 随笔-SQL的三种存储引擎即三种类型的表

    MYSQL 的环境变量:......server/bin下 引擎(Engine):是电子平台上开发程序或系统的核心组件.利用引擎,开发者可迅速建立.铺设程序所需的功能,或利用其辅助程序的运转.一般而言 ...

  4. 2.1synchronized同步方法

    由前言: 在第一章已经出现了非线程安全的情况."非线程安全"其实会发生在多个线程同时对同一个对象中的实例变量进行访问时发生.产生的结果就是脏读(读到被修改过的数据). " ...

  5. 【C#入门教案-02】用记事本编写第一个C#程序-Hello World

    02-用记事本编写第一个C#程序-Hello World 广东职业技术学院  欧浩源 [1]进行.NET程序开发的最基本环境配备 .NET Framework + 代码编辑工具(记事本或Noetpad ...

  6. B2B电商系统开发建设的价格费用取决于哪些要素

    B2B电子商务系统平台建设开发怎么做?如何搭建一个电商系统网站平台?相信我们的企业商家在搭建电子商务系统的时候都会进行前期的系统策划,但是对于电子商务系统的构建绝大多数人都有一个误区,那就是对于电子商 ...

  7. java系列视频教程下载

    1.马士兵J2SE基础录屏视频 珍藏版 链接:https://pan.baidu.com/s/1eRMJqkq    密码:qa66 2.spring视频教程 链接:https://pan.baidu ...

  8. SQL Server学习之路(六):“增删改查”之“查”

    0.目录 1.前言 2.最基本的SQL查询语句 3.select...from... 3.1 "*"与"Top num *" 3.2 查询指定列 3.3 Isn ...

  9. Python学习之--socket续集

    IO多路复用: I/O多路复用指:通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作. 一个很简单的linux例子,select,poll, ...

  10. [置顶] spring集成mina 实现消息推送以及转发

    spring集成mina: 在学习mina这块时,在网上找了很多资料,只有一些demo,只能实现客户端向服务端发送消息.建立长连接之类.但是实际上在项目中,并不简单实现这些,还有业务逻辑之类的处理以及 ...