需求如下,客户输入标题
3F
2A
1
1L
2
9D
10A
3
排序结果变成
1
1L
2
2A
3
3F
9D
10A
标题可能为纯数字,也可能数字后面带字母,首先按照数字大小排序,如果后面跟字母的话,再根据字母排序
我是这样做的,排序吗,首先对数据进行第一轮处理,把所有数据格式统一,首先写一个非常简单的正则表达式
/^(\d+)(.*)$/
这个正则匹配两个东西,首先是前面的数字,然后是后面的ABC
这种编号
preg_match("/^(\d+)(.*)$/", '3F', $matches
)
那么结果如下
Array
(
[0] => 3F
[1] => 3
[2] => F
)
$matches[1] 的内容是我们要匹配的数字
$matches[2]的内容是后面可能会有的字母编号
首先要个每个数组元素配置一个权重
下一步看看是否存在字母标号
if(!empty($matches[2])) {
// 首先要减去一个权重,这个权重就是数字*10000,我们保留10000个位置作为排序空间
// 如果没有这一步的话只做ASCII表排序会出现这样一种问题 1D 会比 2A大,排序会出现问题
$arrayElement['weight'] -= $maches[1] * 10000;
// 如果存在后面的字母标号,相加ASCII码标号,就可以拿到最后的这个权重了
if (!empty($matches[2])) {
for ($i = 0; $i < strlen($matches[2]); $i++) {
$arrayElement['weight'] += ord($matches[2][$i]);
}
}
}
后面使用这个$arrayElement['weight']
字段进行排序就可以了