我正在使用
foreach ($objs as $obj) {
$data[] = $obj->getValue;
}
从可能返回的方法中收集值
array[4]{
[0]=>
string(2) "1234"
[1]=>
string(7) "5678"
[2]=>
string(7) "9ab"
[3]=>
string(10) "cdefg"
...
}
但我需要多维关联数组格式的数据,比如......
array[2]{
[0] =>
array[2]{
["alpha"]=>
string(2) "1234"
["beta"]=>
string(7) "5678"
}
[1] =>
array[2]{
["alpha"]=>
string(7) "9ab"
["beta"]=>
string(10) "cdefg"
}
我已经能够通过两个独立的循环来做到这一点,一个将方法数据循环到一个二维数组中,第二个循环遍历该数组并将索引值手动更改为关联值。
$key_labels = array('alpha','beta');
$row_num = $col_num = 0;
$rows = array(
array(),
array()
);
/* Parse the query into a two-dimensional array */
foreach ($objs as $obj) {
$rows[$row_num][$col_num++] = $obj->nodeValue;
if ($col_num == count($key_labels)) {
$col_num = 0;
$row_num++;
}
}
/* Change the array second dimension index values to associative values */
foreach ($rows as $rows_idx => $row) {
unset($rows[$rows_idx]);
foreach ($row as $row_idx => $row_val) {
$rows[$rows_idx][$key_labels[$row_idx]] = $row_val;
}
}
var_dump($rows);
我的问题是……有没有办法比使用两个冗长(而且看似笨拙)的循环更直接地完成这个任务?或者这真的是最好的方法吗?
注意:预计该对象将始终返回等于计数的某个偶数因子的行$key_labels
数。