在PHP中迭代复杂的关联数组

时间:2008-08-25 13:17:18

标签: php arrays associative-array

有没有一种简单的方法可以在PHP中迭代这个结构的关联数组:

数组$searches具有编号索引,具有4到5个关联部分。因此,我不仅需要遍历$searches[0]$searches[n],还需要$searches[0]["part0"]$searches[n]["partn"]。困难的部分是不同的索引具有不同数量的部分(有些可能缺少一个或两个)。

以一种美好,整洁,易懂的方式做到这一点的想法?

7 个答案:

答案 0 :(得分:40)

嵌套两个foreach loops

foreach ($array as $i => $values) {
    print "$i {\n";
    foreach ($values as $key => $value) {
        print "    $key => $value\n";
    }
    print "}\n";
}

答案 1 :(得分:40)

我知道这是一个神秘的问题,但使用Spl Iterators迭代多维数组

$iterator = new RecursiveIteratorIterator(new RecursiveArrayIterator($array));

foreach($iterator as $key=>$value) {
    echo $key.' -- '.$value.'<br />';
}

答案 2 :(得分:13)

看起来像递归函数的好地方,尤其是。如果你有两个以上的深度。

function doSomething(&$complex_array)
{
    foreach ($complex_array as $n => $v)
    {
        if (is_array($v))
            doSomething($v);
        else
            do whatever you want to do with a single node
    }
}

答案 3 :(得分:5)

您应该能够使用嵌套的foreach语句

来自php manual

/* foreach example 4: multi-dimensional arrays */
$a = array();
$a[0][0] = "a";
$a[0][1] = "b";
$a[1][0] = "y";
$a[1][1] = "z";

foreach ($a as $v1) {
    foreach ($v1 as $v2) {
        echo "$v2\n";
    }
}

答案 4 :(得分:0)

你可以循环遍历所有“part [n]”项并使用isset查看它们是否真的存在吗?

答案 5 :(得分:0)

我真的不确定你的意思 - 当然,你需要一对foreach循环吗?

foreach($array as $id => $assoc)
{
    foreach($assoc as $part => $data)
    {
        // code
    }
}

或者你需要一些递归的东西吗?我可以通过示例数据和您希望数据返回的上下文来提供更多帮助。

答案 6 :(得分:0)

考虑这个多维数组,我希望这个函数能有所帮助。

$n = array('customer' => array('address' => 'Kenmore street',
                'phone' => '121223'),
      'consumer' => 'wellington consumer',
      'employee' => array('name' => array('fname' => 'finau', 'lname' => 'kaufusi'),
                     'age' => 32,
                 'nationality' => 'Tonga')
      );



iterator($n);

function iterator($arr){

    foreach($arr as $key => $val){

    if(is_array($val))iterator($val);

    echo '<p>key: '.$key.' | value: '.$val.'</p>';

    //filter the $key and $val here and do what you want
    }

}