"PHP 다중정렬 sortOrderBy()"의 두 판 사이의 차이

잔글 (Jmnote님이 PHP 함수 orderBy() 문서를 PHP 다중정렬 sortValues() 문서로 이동했습니다)
잔글 (Jmnote님이 PHP 다중정렬 sortValues() 문서를 PHP 다중정렬 sortOrderBy() 문서로 이동했습니다)
 
(같은 사용자의 중간 판 5개는 보이지 않습니다)
1번째 줄: 1번째 줄:
==개요==
==개요==
;PHP 다중정렬 orderBy()
;PHP 다중정렬 sortValues()
;PHP 다중정렬 sortValues()
;PHP 다중정렬 sortOrderBy()


<syntaxhighlight lang='php' line run>
<syntaxhighlight lang='php' line run>
<?php
function sortValues($array, $by, $ascending=[]) {
function sortValues($array, $by, $ascending=[]) {
     $makeComparer = function ($criteria) {
     $makeComparer = function ($criteria) {
         $comparer = function ($a, $b) use ($criteria) {
         return function ($a, $b) use ($criteria) {
             for($i=0; $i<count($criteria[0]); $i++) {
             foreach( $criteria[0] as $i => $key) {
                $key = $criteria[0][$i];
                 $asc = $criteria[1][$i] ?? true;
                 $asc = $criteria[1][$i] ?? true;
                 if ($a[$key] < $b[$key]) return $asc ? -1 : 1;
                 if ($a[$key] < $b[$key]) return $asc ? -1 : 1;
15번째 줄: 16번째 줄:
             return 0;
             return 0;
         };
         };
        return $comparer;
     };
     };
     $comparer = $makeComparer([$by, $ascending]);
     usort($array, $makeComparer([$by, $ascending]));
    usort($array, $comparer);
     return $array;
     return $array;
}
}
30번째 줄: 29번째 줄:


# BirthDate 오름차순
# BirthDate 오름차순
$employees = sortValues($employees, ['BirthDate']);
$employees1 = sortValues($employees, ['BirthDate']);
echo preg_replace('/\\},/',"},\n",json_encode($employees,JSON_UNESCAPED_UNICODE))."\n\n";
 
# BirthDate 내림차순
# BirthDate 내림차순
$employees = sortValues($employees, ['BirthDate'],[false]);
$employees2 = sortValues($employees, ['BirthDate'], [false]);
echo preg_replace('/\\},/',"},\n",json_encode($employees,JSON_UNESCAPED_UNICODE))."\n\n";
 
# BirthDate, Name 오름차순
# BirthDate, Name 오름차순
$employees = sortValues($employees, ['BirthDate','Name']);
$employees3 = sortValues($employees, ['BirthDate','Name']);
echo preg_replace('/\\},/',"},\n",json_encode($employees,JSON_UNESCAPED_UNICODE))."\n\n";
# BirthDate 오름차순, Name 내림차순
$employees4 = sortValues($employees, ['BirthDate','Name'], [true,false]);


# BirthDate 오름차순, Name 내림차순
# 출력
$employees = sortValues($employees, ['BirthDate','Name'], [true,false]);
for($i=1; $i<=4; $i++) {
echo preg_replace('/\\},/',"},\n",json_encode($employees,JSON_UNESCAPED_UNICODE))."\n\n";
    $var = "employees$i";
    echo "$var: \n", str_replace('},',"},\n",json_encode($$var,JSON_UNESCAPED_UNICODE))."\n\n";
}
</syntaxhighlight>
</syntaxhighlight>



2021년 10월 2일 (토) 16:28 기준 최신판

1 개요[ | ]

PHP 다중정렬 orderBy()
PHP 다중정렬 sortValues()
PHP 다중정렬 sortOrderBy()
function sortValues($array, $by, $ascending=[]) {
    $makeComparer = function ($criteria) {
        return function ($a, $b) use ($criteria) {
            foreach( $criteria[0] as $i => $key) {
                $asc = $criteria[1][$i] ?? true;
                if ($a[$key] < $b[$key]) return $asc ? -1 : 1;
                if ($a[$key] > $b[$key]) return $asc ? 1 : -1;
            }
            return 0;
        };
    };
    usort($array, $makeComparer([$by, $ascending]));
    return $array;
}

$employees = [
	['EmployeeID'=>'1', 'Name'=>'한놈', 'BirthDate'=>'1999-01-01'],
	['EmployeeID'=>'2', 'Name'=>'두시기', 'BirthDate'=>'2000-01-01'],
	['EmployeeID'=>'3', 'Name'=>'석삼', 'BirthDate'=>'1999-01-01'],
	['EmployeeID'=>'4', 'Name'=>'너구리', 'BirthDate'=>'2000-01-01'],
];

# BirthDate 오름차순
$employees1 = sortValues($employees, ['BirthDate']);
# BirthDate 내림차순
$employees2 = sortValues($employees, ['BirthDate'], [false]);
# BirthDate, Name 오름차순
$employees3 = sortValues($employees, ['BirthDate','Name']);
# BirthDate 오름차순, Name 내림차순
$employees4 = sortValues($employees, ['BirthDate','Name'], [true,false]);

# 출력
for($i=1; $i<=4; $i++) {
    $var = "employees$i";
    echo "$var: \n", str_replace('},',"},\n",json_encode($$var,JSON_UNESCAPED_UNICODE))."\n\n";
}

2 같이 보기[ | ]

3 참고[ | ]

문서 댓글 ({{ doc_comments.length }})
{{ comment.name }} {{ comment.created | snstime }}