4

如何对这个版本值数组进行排序?

$available_databases = array(
    "4.0.1",
    "trunk",
    "branch",
    "4.1.0",
    "4.0.3"
);

所以结果是

4.1.0
4.0.3
4.0.1
branch
trunk
4

4 回答 4

5

您应该使用usort功能。

$isVersion = function($a) { return is_numeric( str_replace('.', '', $a) ); };
$sortFunction = function($a, $b) use($isVersion) { 
    if( $isVersion($a) && $isVersion($b) ) { 
        return version_compare($b, $a); // reversed for your proper ordering
    } elseif( $isVersion($a) ) { 
        return -1;
    } elseif( $isVersion($b) ) { 
        return 1;
    } else { 
        return strcasecmp($a, $b);
    }
};

usort($yourArray, $sortFunction);

usort 函数允许您使用自己的自定义比较回调。我用你想要的逻辑在这里为你写了一个:如果两个可比较的项目都是版本,它用于version_compare将它们与反转的参数进行比较,因为你想要降序。如果第二个可比较项是字符串而第一个是版本,则该版本被称为“低于”字符串,反之亦然。如果两个项目都是字符串,它使用strcasecmp比较函数来确定正确的顺序。

使用示例:键盘

于 2012-08-31T02:27:42.910 回答
2

您可以使用 PHP 的内置数组操作等来为您完成很多繁重的工作,从而减少了很多明显的复杂性:

$names = preg_grep('/^\D/', $arr);
$versions = preg_grep('/^\d/', $arr);

usort($versions, 'version_compare');
usort($names, 'strcasecmp');

$sorted = array_merge(array_reverse($versions), $names);
于 2012-09-02T04:19:15.327 回答
1

它可以通过一些数组函数和几个循环来完成。

例子:

<?php
$arr = array("4.0.1", "trunk", "branch", "4.1.0", "4.0.3", "1.2", "1.31", "1.10", "1.4.5");
natsort($arr);
$count = count($arr);
$alpha = array();
$new_arr = array();
for($i = 0; $i < $count; $i++) {
    if(!is_numeric(str_replace('.', '', $arr[$i]))) {
        $alpha[] = $arr[$i];
    } else {
        $new_arr[] = $arr[$i];
    }
    $arr[$i] = null;
}
rsort($new_arr);
sort($alpha);
$new_arr = array_merge($new_arr, $alpha);
var_dump($new_arr);
?>

演示在这里。

于 2012-08-31T02:42:05.227 回答
0

您只需要反转version_compare()评估。

代码:(演示

$array = ["4.0.1", "trunk", "branch", "4.1.0", "4.0.3"];

usort($array, function($a, $b) {
    return version_compare($b, $a);
});

var_export($array);

输出:

array (
  0 => '4.1.0',
  1 => '4.0.3',
  2 => '4.0.1',
  3 => 'branch',
  4 => 'trunk',
)

从 PHP7.4 开始,可以使用箭头函数语法。(演示

usort($array, fn($a, $b) => version_compare($b, $a));
于 2019-12-23T04:18:33.973 回答