function array_sort($array, $key){ if(is_array($array)){ $key_array = null; $new_array = null; for( $i = 0; $i < count( $array ); $i++ ){ $key_array[$array[$i][$key]] = $i; } ksort($key_array); $j = 0; foreach($key_array as $k => $v){ $new_array[$j] = $array[$v]; $j++; } unset($key_array); return $new_array; }else{ return $array; } }
PHP의 2차원 배열은 키 값으로 정렬됩니다
PHP의 array_multisort()는 여러 배열을 한 번에 정렬하거나 다차원 배열을 특정 차원 또는 특정 차원에 따라 정렬하는 데 사용할 수 있습니다. 여러 차원. 연관된 키 이름은 변경되지 않은 채로 유지되지만 숫자 키 이름은 다시 색인화됩니다. 입력 배열은 테이블의 열로 처리되며 행별로 정렬됩니다. 첫 번째 배열이 정렬할 기본 배열이 됩니다. 배열의 행(값)이 동일한 것으로 비교되면 다음 입력 배열의 해당 값 크기에 따라 정렬됩니다.
그러나 정렬하려는 배열이 2차원 배열인 경우 배열의 키 값에 따라 정렬해야 합니다. 예를 들어 아래 2차원 배열은 다음과 같이 정렬해야 합니다. 정렬 키 이름으로 지정하면 array_multisort()를 직접 구현할 수 없습니다.
$data[5] = array('volume' => 67, 'edition' => 2); $data[4] = array('volume' => 86, 'edition' => 1); $data[2] = array('volume' => 85, 'edition' => 6); $data[3] = array('volume' => 98, 'edition' => 2); $data[1] = array('volume' => 86, 'edition' => 6); $data[6] = array('volume' => 67, 'edition' => 7); // 准备要排序的数组 foreach ($data as $k => $v) { $edition[] = $v['edition']; } array_multisort($edition, SORT_ASC, $data); print_r($data);
은 다음과 같이 출력됩니다.
Array ( [0] => Array ( [volume] => 86 [edition] => 1 ) [1] => Array ( [volume] => 67 [edition] => 2 ) [2] => Array ( [volume] => 98 [edition] => 2 ) [3] => Array ( [volume] => 85 [edition] => 6 ) [4] => Array ( [volume] => 86 [edition] => 6 ) [5] => Array ( [volume] => 67 [edition] => 7 ) )
원래 키를 파괴하지 않기 위해 정렬을 작성했습니다. 2차원 배열만 지원하는 함수입니다.
/** * 根据数组中的某个键值大小进行排序,仅支持二维数组 * * @param array $array 排序数组 * @param string $key 键值 * @param bool $asc 默认正序 * @return array 排序后数组 */ function arraySortByKey(array $array, $key, $asc = true) { $result = array(); // 整理出准备排序的数组 foreach ( $array as $k => &$v ) { $values[$k] = isset($v[$key]) ? $v[$key] : ''; } unset($v); // 对需要排序键值进行排序 $asc ? asort($values) : arsort($values); // 重新排列原有数组 foreach ( $values as $k => $v ) { $result[$k] = $array[$k]; } return $result; }
지정된 키 값으로 2차원 배열을 정렬하는 더 많은 PHP 샘플 코드를 보려면 PHP 중국어 웹사이트를 주목하세요!