我遇到了递归函数,我找不到任何可以完成我需要的东西,所以我希望有人可以帮我解决这个问题。 我有一个给定驱动器的多维目录数组,我需要将它们转换为EACH最深子目录的完整路径字符串。这是阵列:
<?php
$array = array(
'CANON' => array(
'DCIM' => array(
'100CANON',
'101CANON',
'CANONMSC'
),
'CANON_SC' => array(
'IMAGE' => array(
'0001'
),
'DOCUMENT' => array(
'0001'
),
),
'MISC'
));
这是所需的输出:
/CANON/DCIM/100CANON/
/CANON/DCIM/101CANON/
/CANON/DCIM/CANONMSC/
/CANON/CANON_SC/IMAGE/0001/
/CANON/CANON_SC/DOCUMENT/0001/
/CANON/MISC/
这是我到目前为止所做的,但它只适用于第一个最深的目录并忽略了兄弟目录。
<?php
function flatten_directory($array, $prefix = '')
{
$result = '';
foreach($array as $key=>$value)
{
if(is_array($value))
{
$result .= $key .'/'. flatten_directory($value, $prefix . $key . '.');
}
else
{
$result .= $prefix . $key . $value;
}
}
return $result;
}
提前谢谢。
答案 0 :(得分:2)
前缀的想法很好,但这部分不起作用,因为你可能得到多个结果:
$result .= $key .'/'. flatten_directory($value, $prefix . $key . '.');
不是返回单个字符串,而是返回一个字符串数组。您还要混淆何时使用$key
和$value
。
function flatten_directory($directory, $prefix = "") {
$result = array();
foreach ($directory as $key => $part) {
if (is_array($part)) {
$result = array_merge($result, flatten_directory($part, $prefix . "/" . $key));
} else {
$result[] = $prefix . "/" . $part . "/";
}
}
return $result;
}
输出:
Array
(
[0] => /CANON/DCIM/100CANON/
[1] => /CANON/DCIM/101CANON/
[2] => /CANON/DCIM/CANONMSC/
[3] => /CANON/CANON_SC/IMAGE/0001/
[4] => /CANON/CANON_SC/DOCUMENT/0001/
[5] => /CANON/MISC/
)
答案 1 :(得分:1)
<?php
$array = array(
'CANON' => array(
'DCIM' => array(
'100CANON',
'101CANON',
'CANONMSC'
),
'CANON_SC' => array(
'IMAGE' => array(
'0001'
),
'DOCUMENT' => array(
'0001'
),
),
'MISC'
));
function arrayToString($array, $parentStr = '')
{
foreach($array as $key => $token)
{
if($token && is_array($token))
{
arrayToString($token, $parentStr . '/' . $key);
}
else
{
echo $parentStr . '/' . $token . '<br>';
}
}
}
arrayToString($array);
?>