一般的版本号中会涉及到多个小数点,且是字符串类型,现有三个版本号,对版本号进行从小到大(由旧到新)排序
原始版本号结构:
array(10) {
[0]=> string(6) "1.0.10"
[1]=> string(6) "1.0.11"
[2]=> string(5) "1.0.5"
[3]=> string(5) "1.0.3"
[4]=> string(5) "1.1.1"
[5]=> string(5) "1.1.0"
[6]=> string(5) "1.1.2"
[7]=> string(5) "1.1.4"
[8]=> string(5) "1.1.3"
[9]=> string(5) "1.1.5"
}
很显然这十个版本号杂乱无章
由于版本从小到大的发布,理想的数据结果肯定是:1.0.3 => 1.0.5 => 1.0.10 => 1.0.11 => 1.1.0 => 1.1.1 => 1.1.2 => 1.1.3 => 1.1.4 => 1.1.5
废话不多说,直接上代码(直接封装调用即可)
public static function sortVersion($versions, $sort_rule = true) { foreach ($versions as $key => $value) { $firstArr = explode('.', $value); $firstArrCount = count($firstArr); for ($i = 0; $i < $firstArrCount; $i++) { $firstArr[$i] = str_pad($firstArr[$i], 2, 0, STR_PAD_LEFT); } $versions[$key] = implode('.', $firstArr); } if ($sort_rule) { sort($versions); } else { rsort($versions); } foreach ($versions as $key => $value) { $firstArr = explode('.', $value); $firstArrCount = count($firstArr); for ($i = 0; $i < $firstArrCount; $i++) { $firstArr[$i] = intval($firstArr[$i]); } $versions[$key] = implode('.', $firstArr); } return $versions; }
我执行完的结果是:
array(10) {
[0]=> string(5) "1.0.3"
[1]=> string(5) "1.0.5"
[2]=> string(6) "1.0.10"
[3]=> string(6) "1.0.11"
[4]=> string(5) "1.1.0"
[5]=> string(5) "1.1.1"
[6]=> string(5) "1.1.2"
[7]=> string(5) "1.1.3"
[8]=> string(5) "1.1.4"
[9]=> string(5) "1.1.5"
}
很理想。
参考原文:https://blog.csdn.net/fhl760925513/article/details/108075626
在原文的基础上做了点改动。