Maison >développement back-end >tutoriel php >Compétences en développement PHP (2) - Un cas d'implémentation d'un tri de tableaux bidimensionnel basé sur la clé

Compétences en développement PHP (2) - Un cas d'implémentation d'un tri de tableaux bidimensionnel basé sur la clé

黄舟
黄舟original
2017-03-10 18:33:132228parcourir

Il existe de nombreuses fonctions intégrées pour traiter les tableaux en PHP. Nous pouvons souvent répondre à nos besoins et obtenir les résultats souhaités en utilisant directement leurs fonctions intégrées, mais parfois nous ne pouvons pas utiliser les fonctions intégrées implémentées. nos exigences, ce qui nous oblige à écrire nos propres algorithmes pour mettre en œuvre nos propres idées. Parlons de la façon de trier un tableau bidimensionnel selon la clé.

Méthode d'implémentation :

<?php  
  
/** 
 * ======================================= 
 * Created by Zhihua_W. 
 * Author: Zhihua_W 
 * Date: 2016/11/26 0002 
 * Time: 下午 2:43 
 * Project: PHP开发小技巧 
 * Power: 实现二维数组根据key进行排序 
 * ======================================= 
 */  
  
/** 
 * 二维数组排序 
 * @param array $arr 需要排序的二维数组 
 * @param string $keys 所根据排序的key 
 * @param string $type 排序类型,desc、asc 
 * @return array $new_array 排好序的结果 
 */  
function array_sort($arr, $keys, $type = &#39;desc&#39;)  
{  
    $key_value = $new_array = array();  
    foreach ($arr as $k => $v) {  
        $key_value[$k] = $v[$keys];  
    }  
    if ($type == &#39;asc&#39;) {  
        asort($key_value);  
    } else {  
        arsort($key_value);  
    }  
    reset($key_value);  
    foreach ($key_value as $k => $v) {  
        $new_array[$k] = $arr[$k];  
    }  
    return $new_array;  
}  
  
$arr = array(  
    array(  
        &#39;name&#39; => &#39;a&#39;,  
        &#39;sex&#39; => &#39;m&#39;,  
        &#39;sort&#39; => 5  
    ),  
    array(  
        &#39;name&#39; => &#39;c&#39;,  
        &#39;sex&#39; => &#39;m&#39;,  
        &#39;sort&#39; => 8  
    ),  
    array(  
        &#39;name&#39; => &#39;g&#39;,  
        &#39;sex&#39; => &#39;m&#39;,  
        &#39;sort&#39; => 3  
    ),  
    array(  
        &#39;name&#39; => &#39;e&#39;,  
        &#39;sex&#39; => &#39;w&#39;,  
        &#39;sort&#39; => 6  
    ),  
    array(  
        &#39;name&#39; => &#39;b&#39;,  
        &#39;sex&#39; => &#39;w&#39;,  
        &#39;sort&#39; => 2  
    ),  
);  
  
//打印出原数组  
print_r($arr);  
//打印出排好序的数组  
print_r(array_sort($arr,&#39;name&#39;));  
  
?>

En imprimant les résultats, on peut voir que le tableau est trié selon "nom".

//原数组  
Array  
(  
    [0] => Array  
        (  
            [name] => a  
            [sex] => m  
            [sort] => 5  
        )  
  
    [1] => Array  
        (  
            [name] => c  
            [sex] => m  
            [sort] => 8  
        )  
  
    [2] => Array  
        (  
            [name] => g  
            [sex] => m  
            [sort] => 3  
        )  
  
    [3] => Array  
        (  
            [name] => e  
            [sex] => w  
            [sort] => 6  
        )  
  
    [4] => Array  
        (  
            [name] => b  
            [sex] => w  
            [sort] => 2  
        )  
  
)  
//排序后数组  
Array  
(  
    [2] => Array  
        (  
            [name] => g  
            [sex] => m  
            [sort] => 3  
        )  
  
    [3] => Array  
        (  
            [name] => e  
            [sex] => w  
            [sort] => 6  
        )  
  
    [1] => Array  
        (  
            [name] => c  
            [sex] => m  
            [sort] => 8  
        )  
  
    [4] => Array  
        (  
            [name] => b  
            [sex] => w  
            [sort] => 2  
        )  
  
    [0] => Array  
        (  
            [name] => a  
            [sex] => m  
            [sort] => 5  
        )  
  
)


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn