www.adminn.cn
站长正能量分享网!

PHP数组分组排序程序代码

AD:阿里云服务器企业会员更优惠 腾讯云香港,韩国免备案服务器1.8折优惠

php中数据排序可以用sort但如果要做到数组分组排序的话我们可以使用ar(www.phpfensi.com)ray_multisort函数或者使用多重复遍历来做,下面看一个例子.

PHP的数组,数组中的内容大致如下:

  1. $list = array
  2.     array(2,3,5), 
  3.     array(2,5,24), 
  4.     array(3,8,6), 
  5.     array(3,2,10), 
  6.     array(4,7,20), 
  7.     array(4,1,15), 
  8.     array(6,4,10), 
  9.     array(7,9,20), 
  10.     ); 

为了方便表达,我把3列数字分别称为,ABC三列.

需求:默认以A列排序为主,如果A列相同则以C列倒序排列相同的元素,B列其实没有参与排序,但是在实际运用中有用,所以我也写出来了.

方法一,代码如下:

  1. $a = $c = array(); 
  2. foreach($list as $val){ 
  3.     $a[] = $val[0]; //a列 
  4.     $c[] = $val[2]; //c列 
  5. //安装a列升序,然后安装b列降序 , 类似sql,orderby a asc,b desc 
  6. array_multisort($a,SORT_ASC , $c, SORT_DESC, $list); 
  7. print_r($list); 

方法二,代码如下:

  1. for($j=0;$j<count($list);$j++) { 
  2.     for($i=count($list)-1;$i>$j;$i–){ 
  3.         if($list[$i][0] == $list[$i-1][0] && $list[$i][2] > $list[$i-1][2]) 
  4.             list($list[$i],$list[$i-1]) = array($list[$i-1],$list[$i]); 
  5.     } 

例子2,例如有下面的数据,从数据库里查出来的,是一个二维数组.

  1. [0] => Array ( [trans_lang_id] => 1 [country_id] => 1 [trans_origin_id] => 1 [page_id] => 1 [trans_content] => test1 
  2. [1] => Array ( [trans_lang_id] => 2 [country_id] => 1 [trans_origin_id] => 2 [page_id] => 1 [trans_content] => test2 
  3. [2] => Array ( [trans_lang_id] => 3 [country_id] => 1 [trans_origin_id] => 3 [page_id] => 1 [trans_content] => test3 
  4. [3] => Array ( [trans_lang_id] => 4 [country_id] => 1 [trans_origin_id] => 4 [page_id] => 1 [trans_content] => test4 
  5. [4] => Array ( [trans_lang_id] => 6 [country_id] => 2 (www.phpfensi.com)[trans_origin_id] => 1 [page_id] => 2 [trans_content] => test5 

怎样按照country_id 和page_id分组,将里面的数据查分成多个数组?

也就是country_id和page_id相同的数据成为一个新数组,因为这样的数据会输出到同一个csv文件,比如文件名为 zh_CN_1.csv,代码如下:

  1. Array Translates: 
  2. US_en:Array (  
  3.         [1] => Array (  
  4.                     [0] => Array ( [0] => test [1] => 测试)  
  5.                     [1] => Array ( [0] => test [1] => 测试)  
  6.                     [2] => Array ( [0] => test [1] => 测试)  
  7.                     [3] => Array ( [0] => test [1] => 测试 ) 
  8.                     )  
  9.             ) 
  10.  
  11. CN_zh:Array (  
  12.         [2] => Array (  
  13.                     [0] => Array ( [0] => There are no user contributed notes for this page. [1] => this belong to another country )  
  14.                         )  
  15.             ) 
  16.  
  17.         foreach ($translates as $translate) { 
  18.             $data[$translate["language_code"] . "_" . $translate['short_name'] ][$translate['page_id']][] = array($translate['content'], $translate['trans_content']); 
  19.         } 
  20.         foreach ($data as $locale_key => $item) { 
  21.             foreach ($item as $page_key => $csvContent) { 
  22.                 $fileName = $locale_key . "_" . $page_key . ".csv"
  23.                 $translationFile->generateCSV($fileName$csvContent); 
  24.             } 

这样的话输出的CSV就像下面的结构:

  1. zh_CN_1.csv 
  2. zh_CN_2.csv 
  3. en_US_1.csv 
  4. en_US_2.csv 

每个csv里面可能有多条数据,就是那些国家语言以及page_id都相同的数据就放在同一个csv里.

模板优惠价: (点击购买)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《PHP数组分组排序程序代码》
文章链接:https://www.adminn.cn/news/7181.html
本站资源模板仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。2021.5月起,网站调整,暂不再分享免费模板。谢谢理解

Adminn.Cn 站长分享圈

帝国CMS精品模板腾讯云优惠券,代金券

本站源码仅供本地环境下学习借鉴研究使用!

源码请勿用于任何涉灰站点!净化网络,站长更有责!

支付宝扫一扫打赏