Heim >Backend-Entwicklung >PHP-Tutorial > php数组的排序有关问题,求解

php数组的排序有关问题,求解

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-06-13 13:26:31928Durchsuche

php数组的排序问题,求解!
/**
*对数组按username从左至右匹配排序,username一样则按cardid从大到小排序
*/
$list = array(
0=>array('cardid'=>1001,'username'=>'zhangsan'),
1=>array('cardid'=>1002,'username'=>'zhangsanfeng'),
2=>array('cardid'=>1003,'username'=>'SBzhangsan'),
3=>array('cardid'=>1005,'username'=>'SBzhangsanisyou'),
4=>array('cardid'=>1007,'username'=>'zhangsan'),
);
匹配字符串:$q = 'zhangsan';

排序后的结果应该为
$list = array(
0=>array('cardid'=>1007,'username'=>'zhangsan'),
1=>array('cardid'=>1001,'username'=>'zhangsan'),
2=>array('cardid'=>1003,'username'=>'zhangsanfeng'),
3=>array('cardid'=>1005,'username'=>'SBzhangsanisyou'),
4=>array('cardid'=>1007,'username'=>'SBzhangsan'),
);


------解决方案--------------------
SQL好使不

SQL code

SELECT * FROM table WHERE username LIKE  '%zhangsan%' ORDER BY LOCATE('zhangsan',username) ASC , cardid DESC
<br><font color="#e78608">------解决方案--------------------</font><br>人家要对数组排序,那就对数组排序呗
PHP code
$list = array(
0=>array('cardid'=>1001,'username'=>'zhangsan'),
1=>array('cardid'=>1002,'username'=>'zhangsanfeng'),
2=>array('cardid'=>1003,'username'=>'SBzhangsan'),
3=>array('cardid'=>1005,'username'=>'SBzhangsanisyou'),
4=>array('cardid'=>1007,'username'=>'zhangsan'),
);
$q = 'zhangsan';
foreach($list as $v) {
  $r1[] = $v['cardid'];
  list($r2[], $r3[]) = explode($q, $v['username']);
}
array_multisort($r2, $r3, $r1, SORT_DESC, $list);
print_r($list);
<br><font color="#e78608">------解决方案--------------------</font><br>楼主给的结果有悖于自己的描述噢。<br><br>
PHP code
"sort.php" 29L, 801C written                                                                                                                                   
[User:root Time:02:58:29 Path:/home/liangdong/php]$ php sort.php 
Array
(
    [4] => Array
        (
            [cardid] => 1007
            [username] => zhangsan
        )

    [1] => Array
        (
            [cardid] => 1002
            [username] => zhangsanfeng
        )

    [0] => Array
        (
            [cardid] => 1001
            [username] => zhangsan
        )

    [3] => Array
        (
            [cardid] => 1005
            [username] => SBzhangsanisyou
        )

    [2] => Array
        (
            [cardid] => 1003
            [username] => SBzhangsan
        )

)
[User:root Time:02:58:31 Path:/home/liangdong/php]$ cat sort.php 
<?php $list = array(
                        array('cardid'=>1001,'username'=>'zhangsan'),
                        array('cardid'=>1002,'username'=>'zhangsanfeng'),
                        array('cardid'=>1003,'username'=>'SBzhangsan'),
                        array('cardid'=>1005,'username'=>'SBzhangsanisyou'),
                        array('cardid'=>1007,'username'=>'zhangsan'),
                );
$name = "zhangsan";

uasort($list, function($left, $right) {
                                global $name;
                                $lndx = strpos($left['username'], $name);
                                $rndx = strpos($right['username'], $name);
                                $lid = $left['cardid'];
                                $rid = $right['cardid'];
                                if ($lndx === false && $rndx !== false || 
                                        $lndx !== false && $rndx === false) { // 不包含名字的算小的
                                        return $lndx === false ? -1 : 1;
                                }
                                if ($lndx == $rndx) {
                                        return $rid - $lid;
                                } else {
                                        return $lndx - $rndx;
                                }
                });

print_r($list);
?>
 <div class="clear">
                 
              
              
        
            </div>
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn