Я знаю, что это уже ответили, но я хотел бы упомянуть, что я опубликовал расширение для решения этой точной проблемы и добавил несколько других функций, таких как возможность прокручивать несколько курсоров, удалять все варианты с несколькими курсорами, кроме самого последний и т. д.
Проверьте здесь https://marketplace.visualstudio.com/items?itemName=danseethaler.tab-through-selections
Вложенное множество два foreach
циклы :
foreach ($array as $i => $values) {
print "$i {\n";
foreach ($values as $key => $value) {
print " $key => $value\n";
}
print "}\n";
}
Похож на хорошее место для рекурсивной функции, особенно если у Вас будет больше чем два уровня глубины.
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
}
}
Необходимо смочь использовать вложенный foreach statment
/* 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";
}
}
Я действительно не уверен, что Вы имеете в виду здесь - конечно, пара циклов foreach делает то, в чем Вы нуждаетесь?
foreach($array as $id => $assoc)
{
foreach($assoc as $part => $data)
{
// code
}
}
Или Вам нужно что-то рекурсивное? Я смог бы помочь больше с данными в качестве примера и контекстом в том, как Вы хотите возвращенные данные.
Можно ли просто циклично выполниться по всем объектам "части [n]" и использовать ли isset, чтобы видеть, существуют ли они на самом деле или нет?
Я знаю, что это вопрос о некромантии, но итерации по поводу многомерных массивов легко с SPL-итераторами
$iterator = new RecursiveIteratorIterator(new RecursiveArrayIterator($array));
foreach($iterator as $key=>$value) {
echo $key.' -- '.$value.'<br />';
}
см.