2014-07-25 74 views
0

我正在使用一个名为subval_sort的函数对多维数组进行排序。第一个和第二个多维数组排序

function subval_sort($a,$subkey) { 
    foreach($a as $k=>$v) { 
    $b[$k] = strtolower($v[$subkey]); 
    } 
    asort($b); 
    foreach($b as $key=>$val) { 
    $c[] = $a[$key]; 
    } 
    return $c; 
} 

$songs = array(
    '1' => array('artist'=>'Bing Crosby', 'songname'=>'White Christmas'), 
    '2' => array('artist'=>'Elvis Presley', 'songname'=>'White Christmas'), 
    '3' => array('artist'=>'Abba', 'songname' =>'Waterloo') 
); 

$songs = subval_sort($songs,'songname'); 
print_r($songs); 

工作正常。现在我想按歌曲名排序,艺术家排在第二位。所以:如果两个(或更多)歌曲名称值相同,我想按艺术家排序。像SQL一样:ORDER BY歌名,艺术家。

你有什么想法如何解决它?

回答

1

您可以使用usort在这里你可以定义自定义比较函数

function cmp($a, $b) 
{ 
    if(strcmp($a['songname'], $b['songname'])) { 
     return strcmp($a['songname'], $b['songname']); 
    } 
    return strcmp($a["artist"], $b["artist"]); 
} 

实现: usort($songs, "cmp");

+1

谢谢!有用! – Kristoffer

相关问题