PHP排序数组子串

时间:2016-10-16 15:36:12

标签: php arrays sorting

我想按年对这个数组进行排序:

Array
(
    [0] => data/pictures/alice/1980
    [1] => data/pictures/alice/1985
    [2] => data/pictures/bob/1981
    [3] => data/pictures/bob/1985
    [4] => data/pictures/bob/1987
    [5] => data/pictures/bob/1989
)

预期结果:

Array
(
    [0] => data/pictures/alice/1980
    [1] => data/pictures/bob/1981
    [2] => data/pictures/alice/1985
    [3] => data/pictures/bob/1985
    [4] => data/pictures/bob/1987
    [5] => data/pictures/bob/1989
)

我已经尝试过不同的排序功能而没有成功。

示例:

asort($paths, SORT_STRING | SORT_FLAG_CASE);

sort($path, SORT_NUMERIC);

4 个答案:

答案 0 :(得分:4)

因为它是一个路径,只需通过basename()映射数组,然后根据它进行排序:

array_multisort(array_map('basename', $paths), SORT_ASC, $paths);

答案 1 :(得分:1)

试试这个

function cmp($a, $b) {
   // if equal, don't do much
   if ($a == $b) {
       return 0;
   }

   $explodedA = explode('/', $a);
   $explodedB = explode('/', $b);
   $yearPartA = $explodedA[count($explodedA) - 1];
   $yearPartB = $explodedB[count($explodedB) - 1];


   if ($explodedPartA == $explodedPartB) { // compare full string
      return ($a < $b) ? -1 : 1;
   }

   return ($yearPartA < $yearPartB) ? -1 : 1;
}

// actual sort of the array $path (e.g. the whole point)
usort($path, "cmp");
但是,请考虑一下,你可能正在做的事情已经爆发了。对于每个数组元素多次,并且首先在阵列上稍微工作可能更便宜。不确定你的阵列有多大......做一些测试。

答案 2 :(得分:0)

$array = ['data/pictures/alice/1980','data/pictures/alice/1985','data/pictures/bob/1981','data/pictures/bob/1985','data/pictures/bob/1987','data/pictures/bob/1989'];

uasort($array, function($a,$b) {
    $y1 = array_pop(explode('/', $a));
    $y2 = array_pop(explode('/', $b));
    if($y1===$y2) {
       // if year the same use other criteria
       if($a===$b) {
          return 0;
       }
       return $a>$b?-1:1;
    };
    return $y1>$y2?-1:1;
});

答案 3 :(得分:-1)

使用usort并在自定义功能中按&#34; /&#34;展开字符串;并比较数组的最后部分。