很多站长朋友们都不太清楚php多个数组排序,今天小编就来给大家整理php多个数组排序,希望对各位有所帮助,具体内容如下:
本文目录一览: 1、 PHP 多个数组的排列组合 2、 php 多维数组排序 3、 PHP数组重新排序 PHP 多个数组的排列组合$a = array(1,2,3,4,5,6,7);
$b = array(1,2,3);
$c = array(1,2,3,4,5,6,7,8,9,10);
$d = array($a,$b,$c);
//计算每一个数组的长度
$len = 1;
$arrLen = count($d); //需要排列数组有多少个
$recIndex = null; //记录当前该取的位置
//foreach 计数
$count_3 = 0;
foreach ($d as $key => $value) {
$lenRec[$count_3] = count($value);
$len = $lenRec[$count_3]*$len;
$recIndex[] = 0;//第一次全部取第0个
$count_3++;
}
//算出% 的值
$count = 1;
foreach ($lenRec as $key => $value) {
$moduloVal = 1;
if($arrLen == $count){
$modulo[] = count($d[$arrLen-1]); //等于最后一个的长度
}else{
$count_1 = 1;
foreach ($lenRec as $index => $item) {
$count_1 > $count $moduloVal = $moduloVal*$item;
$count_1 ++;
}
$modulo[] = $moduloVal;
}
$count ++;//为了防止$d key是有值的 不是自然序列 需要计数
}
$i = 1;
while ( $i <= $len) {
$html = '';
$count_2 = 0;// 取模
$temp = '';
foreach ($d as $value) {
$html .= $value[$recIndex[$count_2]%$lenRec[$count_2]].",";
$count_2 ++;
}
echo $html."<br>";
foreach ($modulo as $key => $value) {
if($i%$value == 0 $key < $arrLen - 1 ){
$recIndex[$key] = $recIndex[$key] +1;
}
if($key == $arrLen - 1){
if($i%$value == 0){
$recIndex[$key] = 0;
}else{
$recIndex[$key] = $recIndex[$key] +1;
}
}
}
$i ++;
//改变获取的位置
}
php 多维数组排序给你思路
首先你得判断每个元素是不是一个数组
if(is_array($arr)) {
}
如果不是数组 则开始和下一个数字进行大小比较
一直到该数组结束
如果是(这里就是一个递归的调用 )
那么进入数组 判断元素是不是一个数组
PHP数组重新排序array_multisort 对多个数组或多维数组进行排序 排序的依据可以是自定义,完全可以用一个一维数组去排序多维数组.
$arrSort = [];
foreach($arr as $info) {
$arrSort[] = $info['o'];
}
sort($arrSort);
array_multisort($arrSort, $arr);
array_multisort
你研究一下.这个是完全可行的.
关于php多个数组排序的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。
查看更多关于php多个数组排序 Php数组排序的详细内容...