我有一些处理以数组格式提供的数据的函数。这些函数都做同样的工作,所以我想将它们合并为一个函数。
问题是,每个阵列都接收不同深度的阵列:使用一维,二维和三维阵列,在未来的某些实现中,甚至可以使用四维阵列。
在任何情况下,重要且必要的数据总是在两个最里面的数组中,所以我需要摆脱外部数组,直到我只有最里面的两个级别。 我怀疑的不仅仅是如何做到这一点,而是如何优雅高效地做到这一点,因为我发现我现在的方法相当笨拙。
目前的方法:
function add() {
$data = func_get_args();
if(count($data)>0) {
if(is_array($data[0])) {
if(is_array($data[0][0])) {
foreach($data[0] as $row) {
$this->items[] = $row;
}
} else {
$this->items[] = $data[0];
}
} else {
$this->items[] = $data;
}
}
}
有些使用例子:
$list->add('one', 'two', 'three', 'four', 'five');
$list->add($data_from_DB_in_array_format);
$list->add(
array(
array('one', 'two', 'three', 'four', 'five'),
array('six', 'seven', 'eight', 'nine', 'ten')
)
);
$list->add(
array(
array(
array('one', 'two', 'three', 'four', 'five'),
array('six', 'seven', 'eight', 'nine', 'ten')
)
)
);
当数据通过func_get_args()恢复时,所有内容都放在一个额外的数组中。
结果必须是这样的:
array(
array('one', 'two', 'three', 'four', 'five'),
array('six', 'seven', 'eight', 'nine', 'ten')
);
答案 0 :(得分:1)
只有一种方法可以实现这一点,它具有递归性和一点阵列功能魔力。这可能不是你的确切解决方案,但是如果你需要更多的帮助,应该让你开始吧:
<?php
$data = array(
'test1' => array(
'test2' => array(
'test3' => array(
'test4' => array(
1,
2,
3
),
'test5' => array(
4,
5,
6
),
'test6' => array(
7,
8,
9
),
)
)
)
);
function returnLast2Levels($item){
if(is_array($item) && is_array(reset($item)) && is_array(reset(reset($item)))){
//This $item has more than 2 levels, delve deeper
return returnLast2Levels(reset($item));
}elseif(is_array($item) && is_array(reset($item)) && !is_array(reset(reset($item)))){
//This $item has 2 levels deep of array
return $item;
}
}
var_dump(returnLast2Levels($data));