非常令人沮丧的时刻,无法弄清楚,最后决定搬家并向 Geeks 询问解决方案。
好的,问题来了。
我有下面的数组,需要通过替换重复记录来转换它,array
合并如下所示。
Array
(
[0] => Array
(
[Index] => Array
(
[id] => 2
[content] => content 2
[user_id] => 1
[page_number] => 25
[book_id] => 1
[tag_id] => 3,2,4
[need_review] => no
[status] => active
[created] => 2013-06-27 12:36:45
[modified] => 2013-06-27 12:36:45
)
[Tag] => Array
(
[id] => 3
[name] => three
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:32:13
[modified] => 2013-06-27 12:32:13
)
[Book] => Array
(
[id] => 1
[name] => Book 1
[description] => book one
[ordervalue] => 0
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:22:26
[modified] => 2013-06-27 12:22:26
)
)
[1] => Array
(
[Index] => Array
(
[id] => 2
[content] => content 2
[user_id] => 1
[page_number] => 25
[book_id] => 1
[tag_id] => 3,2,4
[need_review] => no
[status] => active
[created] => 2013-06-27 12:36:45
[modified] => 2013-06-27 12:36:45
)
[Tag] => Array
(
[id] => 2
[name] => two
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:31:58
[modified] => 2013-06-27 12:31:58
)
[Book] => Array
(
[id] => 1
[name] => book 1
[description] => book one
[ordervalue] => 0
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:22:26
[modified] => 2013-06-27 12:22:26
)
)
[2] => Array
(
[Index] => Array
(
[id] => 1
[content] => content1
[user_id] => 1
[page_number] => 10
[book_id] => 2
[tag_id] => 1,2,3
[need_review] => no
[status] => active
[created] => 2013-06-27 12:32:17
[modified] => 2013-06-27 12:32:17
)
[Tag] => Array
(
[id] => 3
[name] => three
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:32:13
[modified] => 2013-06-27 12:32:13
)
[Book] => Array
(
[id] => 2
[name] => book2
[description] => book two
[ordervalue] => 2
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:24:04
[modified] => 2013-06-27 12:24:04
)
)
[3] => Array
(
[Index] => Array
(
[id] => 1
[content] => content1
[user_id] => 1
[page_number] => 10
[book_id] => 2
[tag_id] => 1,2,3
[need_review] => no
[status] => active
[created] => 2013-06-27 12:32:17
[modified] => 2013-06-27 12:32:17
)
[Tag] => Array
(
[id] => 2
[name] => two
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:31:58
[modified] => 2013-06-27 12:31:58
)
[Book] => Array
(
[id] => 2
[name] => book2
[description] => book two
[ordervalue] => 2
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:24:04
[modified] => 2013-06-27 12:24:04
)
)
)
我想将此数组转换为下面。
Array
(
[0] => Array
(
'Tag' => Array
(
[id] => 2
[name] => two
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:31:58
[modified] => 2013-06-27 12:31:58,
[Book] => Array
(
[id] => 2
[name] => book2
[description] => book two
[ordervalue] => 2
[user_id] => 1
[status] => active
[created] => 2013-06-27 12:24:04
[modified] => 2013-06-27 12:24:04
[Index] => Array
(
'0' => Array
(
[id] => 1
[content] => content1
[user_id] => 1
[page_number] => 10
[book_id] => 2
[tag_id] => 1,2,3
[need_review] => no
[status] => active
[created] => 2013-06-27 12:32:17
[modified] => 2013-06-27 12:32:17
),
'1' => Array
(
[id] => 2
[content] => content 2
[user_id] => 1
[page_number] => 25
[book_id] => 1
[tag_id] => 3,2,4
[need_review] => no
[status] => active
[created] => 2013-06-27 12:36:45
[modified] => 2013-06-27 12:36:45
)
)
)
)
)
)
等等。
我试过什么?
$newindexes = array();
for( $i = 0; $i < count($indexes);$i++ )
{
$newindexes[$i]['Book'] = $indexes[$i]['Book'];
$newindexes[$i]['Book']['Index'] = array();
for( $k = 0; $k < count($indexes);$k++ )
{
if($indexes[$i]['Book']['id'] == $indexes[$k]['Book']['id'])
{
$newindexes[$i]['Book']['Index'][] = $indexes[$k]['Index'];
}
}
}
并$newindexes = array_map("unserialize", array_unique(array_map("serialize", $newindexes)));
在最后添加以删除重复项但仍然无法正常工作。
花了将近4-5个小时,但无法弄清楚。
请大家看看并在我的代码中给我一些更正或提供一个有用的链接。
非常感谢。