有没有一种简单的方法可以在PHP中迭代这个结构的关联数组:
数组$searches
具有编号索引,具有4到5个关联部分。因此,我不仅需要遍历$searches[0]
到$searches[n]
,还需要$searches[0]["part0"]
到$searches[n]["partn"]
。困难的部分是不同的索引具有不同数量的部分(有些可能缺少一个或两个)。
以一种美好,整洁,易懂的方式做到这一点的想法?
答案 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
}
}