我有一个多维数组,它包含多个会话ID和一个字段数据数组,如下所示:
Array
(
[102] => Array
(
[session_id] => A11.. etc
[fields] => Array
(
[0] => Array
(
[date_time] => 2013-03-25 16:28:56
[ip_address] => xx.xxx.x.xxx
[user_name] => public.static
[session_type] => Start
)
[1] => Array
(
[date_time] => 2013-03-25 16:28:56
[ip_address] => xx.xxx.x.xxx
[user_name] => public.static
[session_type] => Start
)
如您所见,前两个字段数组记录包含相同的数据。到目前为止,我编写了以下PHP代码,使其独一无二,并按日期排序。
for($i = 0; $i<count($unsortedOutput); $i++) {
usort($unsortedOutput[$i]['fields'], 'sortFunction');
$unique[] = array_map('unserialize', array_unique(array_map('serialize', $unsortedOutput[$i]['fields'])));
}
这样可行,但是当我打印$unique
数组时,它(按预期方式)会删除[session_id]
和[fields]
键:
Array
(
[102] => Array
(
[0] => Array
(
[date_time] => 2013-03-25 16:28:56
[ip_address] => 94.229.1.233
[user_name] => public.static
[session_type] => Start
)
我的问题是:
如何在保持整个结构的同时使多维数组独一无二。我觉得我很接近,但无法弄清楚其余部分。
答案 0 :(得分:1)
作为替代方案,您还可以使用foreach
&
引用每个副本进行更改:
foreach($unsortedOutput as &$o) {
usort($o['fields'], 'sortFunction');
$o['fields'] = array_map('unserialize', array_unique(array_map('serialize', $o['fields'])));
}