循环耗费时间,我们都知道。这正是我试图避免的事情,即使它是小规模的。每一点都有帮助。好吧,如果它当然没有取消:)
我有一个阵列:
array(3) {
'0' => array(2) {
'id' => 1234,
'name' => 'blablabla',
},
'1' => array(2) {
'id' => 1235,
'name' => 'ababkjkj',
},
'2' => array(2) {
'id' => 1236,
'name' => 'xyzxyzxyz',
},
}
我要做的是按如下方式转换此数组:
array(3) {
'1234' => 'blablabla',
'1235' => 'asdkjrker',
'1236' => 'xyzxyzxyz',
}
我想这不是一件很难的事情,但我的思绪现在已被破坏,除了循环以外,我无法想到任何事情。
答案 0 :(得分:25)
只需使用array_combine
和array_column
作为
array_combine(array_column($array,'id'), array_column($array,'name'));
如果你有PHP<
,你可以简单地使用array_walk
。 5.5作为
$result = array();
array_walk($array, function($v)use(&$result) {
$result[$v['id']] = $v['name'];
});
<强>编辑:强>
对于拥有PHP&gt;的未来用户5.5可以简单地使用array_column
作为
array_column($array,'name','id');
答案 1 :(得分:8)
UPD :警告最慢的解决方案!见下面的基准。
试试这段代码:
$a = array(array('id' => 1234,
'name' => 'blablabla'),
array('id' => 1235,
'name' => 'ababkjkj'),
array('id' => 1236,
'name' => 'xyzxyzxyz'));
var_export(array_reduce($a, function($res, $item) {
$res[$item['id']] = $item['name'];
return $res;
}));
即使在PHP 5.3中也能正常工作。并且只使用一个函数array_reduce
。
<强> UPD:强> 以下是一些基准测试(中等质量服务器上的Debian 7上的PHP 5.6):
$a = [];
for ($i = 0; $i < 150000; $i++) {
$a[$i] = ['id' => $i,
'name' => str_shuffle('abcde') . str_shuffle('01234')];
}
$start = microtime(true);
if (false) {
// 7.7489550113678 secs for 15 000 itmes
$r = array_reduce($a, function($res, $item) {
$res[$item['id']] = $item['name'];
return $res;
});
}
if (false) {
// 0.096649885177612 secs for 150 000 items
$r = array_combine(array_column($a, 'id'),
array_column($a, 'name'));
}
if (true) {
// 0.066264867782593 secs for 150 000 items
$r = [];
foreach ($a as $subarray) {
$r[$subarray['id']] = $subarray['name'];
}
}
if (false) {
// 0.32427287101746 secs for 150 000 items
$r = [];
array_walk($a, function($v) use (&$r) {
$r[$v['id']] = $v['name'];
});
}
echo (microtime(true) - $start) . ' secs' . PHP_EOL;
因此,作为结论: 普通迭代简单for
循环是一个赢家(如本{{ 3}})。在第二个地方,array_combine
仅允许新版本的PHP。最糟糕的情况是使用我自己的闭包和array_reduce
解决方案。
答案 2 :(得分:7)
如果你有php&gt; = 5.5:
$res = array_combine(array_column($source, 'id'), array_column($source, 'name'));
如果没有 - 制作一个循环。
答案 3 :(得分:4)
使用array_map函数,(PHP 4&gt; = 4.0.6,PHP 5)
[akshay@localhost tmp]$ cat test.php
<?php
$array = array(
array('id' => 1234,'name' => 'blablabla'),
array('id' => 1235,'name' => 'ababkjkj'),
array('id' => 1236,'name' => 'xyzxyzxyz')
);
$output = array();
array_map(function($_) use (&$output){ $output[$_['id']] = $_['name']; },$array);
// Input
print_r($array);
// Output
print_r($output);
?>
<强>输出强>
[akshay@localhost tmp]$ php test.php
Array
(
[0] => Array
(
[id] => 1234
[name] => blablabla
)
[1] => Array
(
[id] => 1235
[name] => ababkjkj
)
[2] => Array
(
[id] => 1236
[name] => xyzxyzxyz
)
)
Array
(
[1234] => blablabla
[1235] => ababkjkj
[1236] => xyzxyzxyz
)
答案 4 :(得分:3)
到目前为止,这是迄今为止最快,最简单的代码......
$result = [];
foreach ($input as $subarray) {
$result[$subarray["id"]] = $subarray["name"];
}
答案 5 :(得分:0)
尝试此功能:
array_combine(array_column($array,'id'), array_column($array,'name'));