PHP多维数组多字段排序分组,处理的数据比较多,望高手解决
原数组
$data = array( 0 => array( 'id' => '510851539496070', 'name' => 'A', 'title' => '108A', 'time' => '1389230133', ), 1 => array( 'id' => '510851539496070', 'name' => 'A', 'title' => '108A', 'time' => '1389230129', ), 2 => array( 'id' => '510940988802058', 'name' => 'A', 'title' => '109A', 'time' => '1389241098', ), 3 => array( 'id' => '510868001733128', 'name' => 'A', 'title' => '109A', 'time' => '1389230169', ), 4 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '132A', 'time' => '1389191699', ), 5 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '136A', 'time' => '1389225520', ), 6 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '143A', 'time' => '1389225520', ), 7 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '143A', 'time' => '1389225520', ), 8 => array( 'id' => '510851539496070', 'name' => 'A', 'title' => '245A', 'time' => '1389230129', ), 9 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '256A', 'time' => '1389191699', ), 10 => array( 'id' => '510868001733128', 'name' => 'A', 'title' => '262A', 'time' => '1389230169', ), 11 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '306A', 'time' => '1389225521', ), 12 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '306A', 'time' => '1389225520', ), 13 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '315A', 'time' => '1389225522', ), 14 => array( 'id' => '510868001733128', 'name' => 'A', 'title' => '403A', 'time' => '1389230169', ), 15 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 16 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 17 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 18 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 19 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 20 => array( 'id' => '510558107108314', 'name' => 'B', 'title' => '40B', 'time' => '1389191699', ), );
( 假设我们把id相同的看成一个组)要求id相同的分组在一起,每个分组之间按title、time再排序
最后输出:
array( 0 => array( 'id' => '510851539496070', 'name' => 'A', 'title' => '108A', 'time' => '1389230129', ), 1 => array( 'id' => '510851539496070', 'name' => 'A', 'title' => '108A', 'time' => '1389230133', ), 2 => array( 'id' => '510851539496070', 'name' => 'A', 'title' => '245A', 'time' => '1389230129', ), 3 => array( 'id' => '510868001733128', 'name' => 'A', 'title' => '109A', 'time' => '1389230169', ), 4 => array( 'id' => '510868001733128', 'name' => 'A', 'title' => '262A', 'time' => '1389230169', ), 5 => array( 'id' => '510868001733128', 'name' => 'A', 'title' => '403A', 'time' => '1389230169', ), 6 => array( 'id' => '510940988802058', 'name' => 'A', 'title' => '109A', 'time' => '1389241098', ), 7 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '132A', 'time' => '1389191699', ), 8 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '256A', 'time' => '1389191699', ), 9 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 10 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 11 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 12 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 13 => array( 'id' => '510558107108314', 'name' => 'A', 'title' => '404A', 'time' => '1389191699', ), 14 => array( 'id' => '510558107108314', 'name' => 'B', 'title' => '40B', 'time' => '1389191699', ), 15 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '136A', 'time' => '1389225520', ), 16 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '143A', 'time' => '1389225520', ), 17 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '143A', 'time' => '1389225520', ), 18 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '306A', 'time' => '1389225520', ), 19 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '306A', 'time' => '1389225521', ), 20 => array( 'id' => '509763928740655', 'name' => 'A', 'title' => '315A', 'time' => '1389225522', ), );
我的做法如下,数据比较多时效率不高! 请高手提供更好的方法:
//先排序title,time foreach ($data as $key => $row) { $title[$key] = $row['title']; $time[$key] = $row['time']; } array_multisort($title, SORT_ASC, SORT_REGULAR, $time, SORT_ASC, SORT_REGULAR, $data); //相同id临时放到一起 $tem = array(); foreach ($data as $value) { $tem[$value['id']][] = $value; } //输出最终结果 $result = array(); foreach ($tem as $sub_arr) { foreach ($sub_arr as $value) { $result[] = $value; } } print_r($result);
回复讨论(解决方案)
这样不行吗
foreach($data as $r) { $id[] = $r['id']; $title[] = $r['title']; $time[] = $r['time'];}array_multisort($id, $title, $time, $data);print_r($data);
这样不行吗
foreach($data as $r) { $id[] = $r['id']; $title[] = $r['title']; $time[] = $r['time'];}array_multisort($id, $title, $time, $data);print_r($data);
这种得不到结果。主要排序是title,time(只是需要将id相同的放在一起)
//输出最终结果
$result = call_user_func_array('array_merge', $tem);
我来学习一下
土豪村长兄么暂时想法和你一样
http://www.9958.pw/post/php_array_multi_sort

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

PHP客戶端URL(curl)擴展是開發人員的強大工具,可以與遠程服務器和REST API無縫交互。通過利用Libcurl(備受尊敬的多協議文件傳輸庫),PHP curl促進了有效的執行

您是否想為客戶最緊迫的問題提供實時的即時解決方案? 實時聊天使您可以與客戶進行實時對話,並立即解決他們的問題。它允許您為您的自定義提供更快的服務

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

使用PHP的cURL庫發送JSON數據在PHP開發中,經常需要與外部API進行交互,其中一種常見的方式是使用cURL庫發送POST�...
