这段代码运行得很好,除非有大小写敏感的东西。我尝试使用strnatcasecmp而不是cmp,它捕获了整个字符串,而不是姓氏。对如何写得更好有什么建议吗?
例如,当前顺序为:
亚伦·卡森
亚当·戴维森
Jen Hennings
埃克托·布鲁茅斯
我想让埃克多·布鲁茅斯在上面。
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');发布于 2019-04-28 07:18:25
我会做这样的事情
$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);最好在从DB创建/读取post对象时创建$aOrderedPosts。另外,我会将它创建为connection类的一个属性。
https://stackoverflow.com/questions/55885048
复制相似问题