Maison développement back-end tutoriel php PHP 多维数组排序 保持索引对应关系 巧用 uasort_PHP教程

PHP 多维数组排序 保持索引对应关系 巧用 uasort_PHP教程

Jul 13, 2016 am 10:30 AM
web开发 企业安全 信息技术 安全软件 数据库 移动开发 系统安全 网站安全 网络安全 网络技术 软件开发

实际开发中,多多少少都会遇到数组的排序问题,除了常规的写简单的排序算法,PHP 还提供了内置数组排序函数,本次重点分享一下:uasort  使用用户自定义的比较函数对数组中的值进行排序并保持索引关联,可排序多维数组,本文重点讲解此函数。      

 
 
 
uasort 函数
 
参数类型:bool uasort ( array &$array, callable $cmp_function)
 
本函数对数组排序并保持索引和单元之间的关联。
 
主要用于对那些单元顺序很重要的结合数组进行排序。比较函数是用户自定义的。
 
成功时返回 TRUE, 或者在失败时返回 FALSE。
 
 
 
数组排序实例(非class中):
 
复制代码
 1 /**
 2  * 自定义排序函数
 3  * @param $param1
 4  * @param $param2
 5  * @return 0(不移动) 1(正向调换顺序) -1(逆向调换顺序)
 6  */
 7 
 8 function my_sort($param1, $param2){
 9     if($param1 == $param2) return 0;
10     else return $param1 > $param2 ? 1 : -1;
11 }
12 
13 $arr = array(
14             'a'=>'20',
15             'b'=>'1',
16             'c'=>'10',
17             'd'=>'5',
18             'e'=>'21',
19             'f'=>'4',
20             'g'=>'3',
21         );
22 
23 uasort($arr, 'my_sort');
24 
25 var_dump($arr);
26 
27 /*输出值
28 array (size=7)
29   'b' => string '1' (length=1)
30   'g' => string '3' (length=1)
31   'f' => string '4' (length=1)
32   'd' => string '5' (length=1)
33   'c' => string '10' (length=2)
34   'a' => string '20' (length=2)
35   'e' => string '21' (length=2)
36 */
复制代码
 
 
多维数组排序实例(非class中):
 
 
 
复制代码
/**
 * 自定义排序函数
 * @param $param1
 * @param $param2
 * @return 0(不移动) 1(正向调换顺序) -1(逆向调换顺序)
 */
 
function my_sort($param1, $param2){
    if($param1['value'] == $param2['value']) return 0;
    else return $param1['value'] > $param2['value'] ? 1 : -1;
}
 
$arr = array(
            'a'=>array('key'=>'定义1', 'value'=>'20'),
            'b'=>array('key'=>'定义2', 'value'=>'1'),
            'c'=>array('key'=>'定义3', 'value'=>'10'),
            'd'=>array('key'=>'定义4', 'value'=>'5'),
            'e'=>array('key'=>'定义5', 'value'=>'21'),
            'f'=>array('key'=>'定义6', 'value'=>'4'),
            'g'=>array('key'=>'定义7', 'value'=>'3'),
        );
 
uasort($arr, 'my_sort');
 
var_dump($arr);
 
/*输出值
array (size=7)
  'b' => 
    array (size=2)
      'key' => string '定义2' (length=7)
      'value' => string '1' (length=1)
  'g' => 
    array (size=2)
      'key' => string '定义7' (length=7)
      'value' => string '3' (length=1)
  'f' => 
    array (size=2)
      'key' => string '定义6' (length=7)
      'value' => string '4' (length=1)
  'd' => 
    array (size=2)
      'key' => string '定义4' (length=7)
      'value' => string '5' (length=1)
  'c' => 
    array (size=2)
      'key' => string '定义3' (length=7)
      'value' => string '10' (length=2)
  'a' => 
    array (size=2)
      'key' => string '定义1' (length=7)
      'value' => string '20' (length=2)
  'e' => 
    array (size=2)
      'key' => string '定义5' (length=7)
      'value' => string '21' (length=2)
*/
复制代码
 
 
 
 
 
 
class中排序,为了方便以二维数组为例:
 
uasort($arr1, array($this, 'public_my_sort'));
 
uasort($arr2, array('self', 'self_my_sort'));
 
复制代码
class myClassSort{
    
    /**
     * 排序主方法
     * @param $arr1  self静态排序
     * @param $arr2  this排序
     * @return 排序后的数组
     */
    public function main($arr1 = array(), $arr2 = array()){
    
        uasort($arr1, array($this, 'public_my_sort'));
        
        uasort($arr2, array('self', 'self_my_sort'));
        
        return array('arr1'=>$arr1, 'arr2'=>$arr2);
    
    }
    
    /**
     * 自定义排序函数
     * @param $param1
     * @param $param2
     * @return 0(不移动) 1(正向调换顺序) -1(逆向调换顺序)
     */
    private static function self_my_sort($param1, $param2){
        if($param1['value'] == $param2['value']) return 0;
        else return $param1['value'] > $param2['value'] ? 1 : -1;
    }
    
    
    //同上
    public function public_my_sort($param1, $param2){
        if($param1['value'] == $param2['value']) return 0;
        else return $param1['value'] > $param2['value'] ? 1 : -1;
    }
    
}
 
$arr = array(
            'a'=>array('key'=>'定义1', 'value'=>'20'),
            'b'=>array('key'=>'定义2', 'value'=>'1'),
            'c'=>array('key'=>'定义3', 'value'=>'10'),
            'd'=>array('key'=>'定义4', 'value'=>'5'),
            'e'=>array('key'=>'定义5', 'value'=>'21'),
            'f'=>array('key'=>'定义6', 'value'=>'4'),
            'g'=>array('key'=>'定义7', 'value'=>'3'),
        );
        
$myClassSort = new myClassSort();
 
var_dump($myClassSort->main($arr, $arr));
 
/*输出结果同以上实例*/
复制代码
 
 
 
 
类似函数扩展
 
   array_multisort 对多个数组或多维数组进行排序,但是最终填入使用的还是具体一维数组
 
   arsort  对一维数组进行逆向排序并保持索引关系,保持索引对应关系
 
   asort  对一维数组进行正向排序并保持索引关系,保持索引对应关系
 
   krsort  对数组按照键名逆向排序,保持索引对应关系
 
   ksort  对数组按照键名正向排序,保持索引对应关系
 
   natcasesort  用“自然排序”算法对一维数组进行不区分大小写字母的排序,可以用来排序数组内容中字母数字混合的情况,保持索引对应关系
 
   natsort  用“自然排序”算法对一维数组排序,区分大小写字母,可以用来排序数组内容中字母数字混合的情况,保持索引对应关系
 
   rsort  对一维数组逆向排序,不保持索引对应关系
 
   sort  对一维数组正向排序,不保持索引对应关系
 
   uasort  使用用户自定义的比较函数对数组中的值进行排序并保持索引关联,可排序多维数组,本文重点讲解此函数
 
   uksort  使用用户自定义的比较函数对数组中的键名进行排序
 
   usort  使用用户自定义的比较函数对数组中的值进行排序,不保持索引关联
 
 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/767108.htmlTechArticle实际开发中,多多少少都会遇到数组的排序问题,除了常规的写简单的排序算法,PHP 还提供了内置数组排序函数,本次重点分享一下:uas...
Déclaration de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

iOS 18 ajoute une nouvelle fonction d'album 'Récupéré' pour récupérer les photos perdues ou endommagées iOS 18 ajoute une nouvelle fonction d'album 'Récupéré' pour récupérer les photos perdues ou endommagées Jul 18, 2024 am 05:48 AM

Les dernières versions d'Apple des systèmes iOS18, iPadOS18 et macOS Sequoia ont ajouté une fonctionnalité importante à l'application Photos, conçue pour aider les utilisateurs à récupérer facilement des photos et des vidéos perdues ou endommagées pour diverses raisons. La nouvelle fonctionnalité introduit un album appelé "Récupéré" dans la section Outils de l'application Photos qui apparaîtra automatiquement lorsqu'un utilisateur a des photos ou des vidéos sur son appareil qui ne font pas partie de sa photothèque. L'émergence de l'album « Récupéré » offre une solution aux photos et vidéos perdues en raison d'une corruption de la base de données, d'une application d'appareil photo qui n'enregistre pas correctement dans la photothèque ou d'une application tierce gérant la photothèque. Les utilisateurs n'ont besoin que de quelques étapes simples

Comment gérer les erreurs de connexion à la base de données en PHP Comment gérer les erreurs de connexion à la base de données en PHP Jun 05, 2024 pm 02:16 PM

Pour gérer les erreurs de connexion à la base de données en PHP, vous pouvez utiliser les étapes suivantes : Utilisez mysqli_connect_errno() pour obtenir le code d'erreur. Utilisez mysqli_connect_error() pour obtenir le message d'erreur. En capturant et en enregistrant ces messages d'erreur, les problèmes de connexion à la base de données peuvent être facilement identifiés et résolus, garantissant ainsi le bon fonctionnement de votre application.

Tutoriel détaillé sur l'établissement d'une connexion à une base de données à l'aide de MySQLi en PHP Tutoriel détaillé sur l'établissement d'une connexion à une base de données à l'aide de MySQLi en PHP Jun 04, 2024 pm 01:42 PM

Comment utiliser MySQLi pour établir une connexion à une base de données en PHP : Inclure l'extension MySQLi (require_once) Créer une fonction de connexion (functionconnect_to_db) Appeler la fonction de connexion ($conn=connect_to_db()) Exécuter une requête ($result=$conn->query()) Fermer connexion ( $conn->close())

Quels sont les avantages et les inconvénients du C++ par rapport aux autres langages de développement web ? Quels sont les avantages et les inconvénients du C++ par rapport aux autres langages de développement web ? Jun 03, 2024 pm 12:11 PM

Les avantages du C++ dans le développement Web incluent la vitesse, les performances et l'accès de bas niveau, tandis que les limites incluent une courbe d'apprentissage abrupte et des exigences de gestion de la mémoire. Lors du choix d'un langage de développement Web, les développeurs doivent tenir compte des avantages et des limites du C++ en fonction des besoins des applications.

Comment utiliser les fonctions de rappel de base de données dans Golang ? Comment utiliser les fonctions de rappel de base de données dans Golang ? Jun 03, 2024 pm 02:20 PM

L'utilisation de la fonction de rappel de base de données dans Golang peut permettre : d'exécuter du code personnalisé une fois l'opération de base de données spécifiée terminée. Ajoutez un comportement personnalisé via des fonctions distinctes sans écrire de code supplémentaire. Des fonctions de rappel sont disponibles pour les opérations d'insertion, de mise à jour, de suppression et de requête. Vous devez utiliser la fonction sql.Exec, sql.QueryRow ou sql.Query pour utiliser la fonction de rappel.

Comment débuter dans le développement web en C++ ? Comment débuter dans le développement web en C++ ? Jun 02, 2024 am 11:11 AM

Pour utiliser C++ pour le développement Web, vous devez utiliser des frameworks prenant en charge le développement d'applications Web C++, tels que Boost.ASIO, Beast et cpp-netlib. Dans l'environnement de développement, vous devez installer un compilateur C++, un éditeur de texte ou IDE et un framework Web. Créez un serveur Web, par exemple en utilisant Boost.ASIO. Gérez les requêtes des utilisateurs, notamment en analysant les requêtes HTTP, en générant des réponses et en les renvoyant au client. Les requêtes HTTP peuvent être analysées à l'aide de la bibliothèque Beast. Enfin, une application Web simple peut être développée, par exemple en utilisant la bibliothèque cpp-netlib pour créer une API REST, en implémentant des points de terminaison qui gèrent les requêtes HTTP GET et POST et en utilisant J

Le potentiel du C++ dans le développement d'applications mobiles : talents et ressources Le potentiel du C++ dans le développement d'applications mobiles : talents et ressources Jun 03, 2024 pm 03:11 PM

Le C++ a un grand potentiel dans le développement mobile en raison : d'une vaste communauté de développeurs et de ressources d'apprentissage riches ; d'une gestion efficace de la mémoire et d'un contrôle de bas niveau, apportant d'excellentes performances, qui peut être écrit une seule fois et exécuté sur Android, iOS et Windows ; Largement utilisé pour le développement de moteurs de jeu, les fonctions de faible latence et de gestion des ressources répondent aux exigences de jeu de haute performance.

Comment enregistrer les données JSON dans la base de données dans Golang ? Comment enregistrer les données JSON dans la base de données dans Golang ? Jun 06, 2024 am 11:24 AM

Les données JSON peuvent être enregistrées dans une base de données MySQL à l'aide de la bibliothèque gjson ou de la fonction json.Unmarshal. La bibliothèque gjson fournit des méthodes pratiques pour analyser les champs JSON, et la fonction json.Unmarshal nécessite un pointeur de type cible pour désorganiser les données JSON. Les deux méthodes nécessitent la préparation d'instructions SQL et l'exécution d'opérations d'insertion pour conserver les données dans la base de données.

See all articles