首页 > 解决方案 > usesort 在由explode函数抓取的区分大小写的字符串中不起作用

问题描述

此代码运行良好,直到某些内容区分大小写。我尝试使用 strnatcasecmp 而不是 cmp,它会抓取整个字符串而不是姓氏。关于如何更好地写这个的任何建议?

例如,当前订单是:
Aaron Carson
Adam Davidson
Jen Hennings
ektor bluemouth


我希望 ektor bluemouth 位居榜首。

foreach($connected->posts as $p) {
$lastname = explode(' ', $p->post_title);
if(sizeof($lastname) == 1) {$p->lastname = $lastname[0];}
if(sizeof($lastname) == 2) {$p->lastname = $lastname[1];}
if(sizeof($lastname) == 3) {$p->lastname = $lastname[2];}
}                           
usort($connected->posts, 'cmp');

标签: phpwordpresssorting

解决方案


我会做这样的事情

$aPosts = array(
    array('post_title' => 'Aaron Carson'),
    array('post_title' => 'Adam Davidson'),
    array('post_title' => 'Jen Hennings'),
    array('post_title' => 'ektor bluemouth'),
);

$aOrderedPosts = array();


foreach($aPosts as $iPos => $p){
    $a = explode(' ', $p['post_title']);
    // cast the last name to lowercase and assign by reference the post
    $aOrderedPosts[strtolower($a[1])] =& $aPosts[$iPos];
    }

var_dump($aOrderedPosts);
// perform a key sort
ksort($aOrderedPosts);
var_dump($aOrderedPosts);

它可以适应您的数据格式

$aOrderedPosts = array();

foreach($connected->posts as $iPos => $p){
    $a = explode(' ', $p->post_title);
    $aOrderedPosts[strtolower($a[1])] =& $connected->posts[$iPos];
}

ksort($aOrderedPosts);
var_dump($aOrderedPosts);

最好$aOrderedPosts在您从数据库创建/读取帖子对象时创建。此外,我会将它创建为connection类的属性。


推荐阅读