创建级联目录的五种方法
创建级联目录的五种方法
方法一:迭代方法
<?php
function mk_dir($path){
//当前目录存在,直接结束该函数。
if(is_dir($path)){
return true;
}
//当前目录不存在,但是当前目录的父目录存在,则在该父目录下创建当前目录,然后直接结束本函数。
if(is_dir(dirname($path))){ //第10行
return mkdir($path); //第11行
}
//当前目录和当前目录的父目录都不存在,则递归调用本函数,并把当前目录的父目录作为参数传递给本函数。当执行完毕本行调用的函数后,应该已经把我们传递过去的参数的这个参数目录创建完毕。
mk_dir(dirname($path));//本行对函数的递归调用应该成功创建了当前目录的父目录,本行为第14行。
return mkdir($path);//在上面的代码行,创建完当前目录的父目录之后,本行创建当前目录,执行完毕后直接结束本函数。
}
//通过上述代码,通过递归依次对当前目录和上级目录,及上上级目录进行判断是否存在,直到发现某个当前目录的父目录存在(也就是第10行成立,接着继续执行第11行,创建我们所发现的那个父目录的子目录,然后结束当前函数(也就是当前正在执行函数的参数目录),返回上级调用该函数的那行代码行),这样就结束了最后一次调用的函数,接着执行上级函数的第14行(倒数第二次调用的函数,因为我们是从第14行开始递归调用,因此最后一次调用的函数执行完毕之后,依然返回到第14行)我们看到,当当前函数所调用的函数执行完毕后,那么当前函数的第14行也就执行完毕,接着执行当前函数的下一行,第15行,因为上一行调用递归函数之后,该次调用(最后一次调用的那个函数)的效果使得创建了当前传入参数路径的父目录,因此第15行创建了当前目录。
//综上我们看到,本函数的作用:输入一个目录的路径,然后当函数执行完毕的时候,实现我们调用该函数时所传入的那个参数目录的创建。
mk_dir('./m/do/jn);
echo 'succeed';
?>
方法二:更简洁的迭代方法。
<?php
function mk_dir($path){//若找不到该目录或该目录的路径,仍然返回false,且无警告输出。
if(is_dir($path)){
return true;
}
return is_dir(dirname($path)) || mk_dir(dirname($path))?mkdir($path):false;
}
echo mk_dir('ma/dong/jun')?'ok':'no';
?>
方法三:函数mkdir()
//事实上在php5.0.0之后,我们php就对mkdir()函数增加了后2个参数。其中用recursive参数,就可以直接创建级联目录,而不必再编写上述代码自定义函数来实现。
<?php
var_dump(mkdir('wang/ya/qianeeg1',0777,true));
//输出:bool(true)
?>
方法四:用迭代压栈出栈数组的形式来创建级联目录
<?php
function mk_dir($path){
$arr=array();
while(!is_dir($path)){
array_unshift($arr,$path);//从数组前面压栈
$path = dirname($path);
}
if(empty($arr)){
return true;
}
print_r($arr);
foreach($arr as $v){
mkdir($v);
}
}
mk_dir('a2/b/v/d/e/f');//
?>
方法五:用迭代压栈出栈数组的形式来创建级联目录
<?php
function mk_dir($path){
$arr=array();
while(!is_dir($path)){
array_push($arr,$path);//从数组后面压栈
$path = dirname($path);
}
if(empty($arr)){
return true;
}
while($pat=array_pop($arr)){//当参数为array()空数组的时array_pop(返回null。
mkdir($pat);
}
}
mk_dir('a22/b/v/d/e/f');//
var_dumP(count(array()));
?>