排序关联数组codeigniter php

Nis*_*ani 0 php arrays sorting codeigniter

这是我想要做的:

$newArray = array();

foreach($student as $s){
    $newArray[$s->id][$s->grade] = $s;
}
Run Code Online (Sandbox Code Playgroud)

我想按照他们的成绩对学生进行排序(更多的是一组而不是一种类型),但我只想要将成绩分类而不是id.我可以不这样做:

$newArray[$s->id] = $s->grade 
asort($newArray)
Run Code Online (Sandbox Code Playgroud)

但是我需要剩下的数据$s.此外,我希望维护每个学生的大量数据.

我怎样才能实现这样的排序?

Eli*_*gem 11

编辑:

你正在一个框架中工作,最好将你的排序回调声明为一个成员函数(当然,在你需要它的同一个类中):

private function sortCB(array $a, array $b)
{//the array type hinting in arguments is optional
    $i = array_keys($a);//but highly recommended 
    $j = array_keys($b);
    if (end($i) === end($j))
    {
        return 0;
    }
    //replace '>' with '<' if you want to sort descending
    return (end($i) > end($j) ? 1 : -1);//this is ascending
}
Run Code Online (Sandbox Code Playgroud)

然后,在需要实际排序的方法中:

uasort($theArray,array($this,'sortCB'));
Run Code Online (Sandbox Code Playgroud)

有关更多示例,请参阅文档.我在这个(笨重的)答案结尾处添加了一个完整的类示例


我在writecodeonline上尝试了这个,这在这种东西上并不是太好,但这确实有效:

$foo = array_fill_keys(array('foo','bar','q','Bond'),array());
$i = '256';
foreach($foo as $k=>$v)
{
    $foo[$k][$i] = $k;
    $i = (string)((int)$i%2 === 0 ? ((int)$i/2)+1 : (int)$i*3);
}
function sortCB($a,$b)
{
    $i = array_keys($a);
    $j = array_keys($b);
    if (end($i) === end($j))
    {
        return 0;
    }
    return (end($i) > end($j) ? 1 : -1);
}
uasort($foo,'sortCB');
var_dump($foo);
Run Code Online (Sandbox Code Playgroud)

但是,既然您正在使用框架,那么您可以将该函数声明为成员函数private function sortCB(array $a,array $b),并像这样使用它:

uasort($foo,array($this, 'sortCB'));
Run Code Online (Sandbox Code Playgroud)

有可能是对如何最好地在一类环境中使用该回调函数的一些更多的信息在这里


完整的示例+用法(测试和工作):

class test
{
    public $foo = null;
    public function __construct()
    {
        $this->foo = array_fill_keys(array('foo','bar','q','Bond'),array());
        $i = '256';
        foreach($this->foo as $k=>$v)
        {
            $this->foo[$k][$i] = $k;
            $i = (string)((int)$i%2 === 0 ? ((int)$i/2)+1 : (int)$i*3);
        }
    }
    private function sortCB($a,$b)
    {
        $i = array_keys($a);
        $j = array_keys($b);
        if (end($i) === end($j))
        {
            return 0;
        }
        return (end($i) > end($j) ? 1 : -1);
    }
    public function sortFoo()
    {
        uasort($this->foo,array($this,'sortCB'));
        print_r($this->foo);
        return $this->foo;
    }
}
$bar = new test();
$arr = $bar->sortFoo();
Run Code Online (Sandbox Code Playgroud)