function mySort($a, $b) {
if (strtolower($a->n) == strtolower($b->n)) return 0;
return (strtolower($a->n) < strtolower($b->n)) ? -1 : 1;
}
这适用于像这样的一些json数据
$txt = '[{"n":"1"},{"n":"2"},{"n":"3"},{"n":"4"},{"n":"5"},{"n":"6"},{"n":"7"},{"n":"8"},{"n":"9"},{"n":"10"},{"n":"11"}]
$j = json_decode($txt);
usort($j, 'mySort');
foreach ($j as $k=>$v) {
echo $v->n.'<br />';//1 2 3 4 5 6 7 8 9 10 11
}
但是当一些数据如下:
$txt = '[{"n":"a 1"},{"n":"a 2"},{"n":"a 3"},{"n":"a 4"},{"n":"a 5"},{"n":"a 6"},{"n":"a 7"},{"n":"a 8"},{"n":"a 9"},{"n":"a 10"},{"n":"a 11"}]';
$j = json_decode($txt);
usort($j, 'mySort');
foreach ($j as $k=>$v) {
echo $v->n.'<br />';//a 1 a 10 a 11 a 2 a 3 a 4 a 5 a 6 a 7 a 8 a 9
}
我需要排序
a 1 a 2 a 3 a 4 a 5 a 6 a 7 a 8 a 9 a 10 a 11
感谢。
答案 0 :(得分:4)
甚至更简单,使用strnatcmp。它执行自然排序,并以对人类来说自然的方式比较元素。
示例:
function mySort($a, $b) {
return strnatcmp($a->n, $b->n);
}
答案 1 :(得分:1)
function mySort2($a, $b) {
list ($k, $n) = explode (' ', $a->n);
list ($l, $m) = explode (' ', $b->n);
if (strtolower($n) == strtolower($m)) return 0;
return (strtolower($n) < strtolower($m)) ? -1 : 1;
}
$txt = '[{"n":"a 1"},{"n":"a 2"},{"n":"a 3"},{"n":"a 4"},{"n":"a 5"},{"n":"a 6"},{"n":"a 7"},{"n":"a 8"},{"n":"a 9"},{"n":"a 10"},{"n":"a 11"}]';
$j = json_decode($txt);
usort($j, 'mySort2');
foreach ($j as $k=>$v) {
echo $v->n.'<br />';//a 1 a 10 a 11 a 2 a 3 a 4 a 5 a 6 a 7 a 8 a 9
}