什么是一个优雅的方式进行排序的对象,在PHP?我会喜欢完成类似的东西。

$sortedObjectArary = sort($unsortedObjectArray, $Object->weight);

基本上指定的列我想要排序,以及领域,我要排序。我看到多层面阵列的分类和可能有一些有用的东西在那里,但我没看到什么优雅的或明显的。

有帮助吗?

解决方案

几乎逐字逐句:

function compare_weights($a, $b) { 
    if($a->weight == $b->weight) {
        return 0;
    } 
    return ($a->weight < $b->weight) ? -1 : 1;
} 

usort($unsortedObjectArray, 'compare_weights');

如果您希望对象能够自行排序,请参阅此处的示例3: http://php.net/usort

其他提示

对于php&gt; = 5.3

function osort(&$array, $prop)
{
    usort($array, function($a, $b) use ($prop) {
        return $a->$prop > $b->$prop ? 1 : -1;
    }); 
}

请注意,这使用匿名函数/闭包。可能会发现查看有用的php文档。

如果您想要这种控制级别,您甚至可以将排序行为构建到您正在排序的类中

class thingy
{
    public $prop1;
    public $prop2;

    static $sortKey;

    public function __construct( $prop1, $prop2 )
    {
        $this->prop1 = $prop1;
        $this->prop2 = $prop2;
    }

    public static function sorter( $a, $b )
    {
        return strcasecmp( $a->{self::$sortKey}, $b->{self::$sortKey} );
    }

    public static function sortByProp( &$collection, $prop )
    {
        self::$sortKey = $prop;
        usort( $collection, array( __CLASS__, 'sorter' ) );
    }

}

$thingies = array(
        new thingy( 'red', 'blue' )
    ,   new thingy( 'apple', 'orange' )
    ,   new thingy( 'black', 'white' )
    ,   new thingy( 'democrat', 'republican' )
);

print_r( $thingies );

thingy::sortByProp( $thingies, 'prop1' );

print_r( $thingies );

thingy::sortByProp( $thingies, 'prop2' );

print_r( $thingies );

对于那个比较功能,您可以这样做:

function cmp( $a, $b )
{ 
    return $b->weight - $a->weight;
} 

usort功能( http://uk.php.net/manual /en/function.usort.php )是你的朋友。有点像...

function objectWeightSort($lhs, $rhs)
{
   if ($lhs->weight == $rhs->weight)
     return 0;

   if ($lhs->weight > $rhs->weight)
     return 1;

   return -1;
}

usort($unsortedObjectArray, "objectWeightSort");

请注意,任何数组键都将丢失。

您可以使用 usort()功能并制作自己的比较功能。

$sortedObjectArray = usort($unsortedObjectArray, 'sort_by_weight');

function sort_by_weight($a, $b) {
    if ($a->weight == $b->weight) {
        return 0;
    } else if ($a->weight < $b->weight) {
        return -1;
    } else {
        return 1;
    }
}

根据问题你都在试图解决的,你还可以找到SPL口有用的。例如,执行ArrayAccess接口将允许访问您的类似的一个阵列。此外,执行SeekableIterator界会让你回路过你的对象就像一阵列。这样你可以按你的对象仅仅因为如果它是一个简单的阵列,具有完全控制价值观的回报给定的关键。

更多的细节:

function PHPArrayObjectSorter($array,$sortBy,$direction='asc')
{
    $sortedArray=array();
    $tmpArray=array();
    foreach($this->$array as $obj)
    {
        $tmpArray[]=$obj->$sortBy;
    }
    if($direction=='asc'){
        asort($tmpArray);
    }else{
        arsort($tmpArray);
    }

    foreach($tmpArray as $k=>$tmp){
        $sortedArray[]=$array[$k];
    }

    return $sortedArray;

}

例如&gt;

$myAscSortedArrayObject=PHPArrayObjectSorter($unsortedarray,$totalMarks,'asc');

$myDescSortedArrayObject=PHPArrayObjectSorter($unsortedarray,$totalMarks,'desc');

您可以使用与 Nspl 的“nofollow”>排序功能:

use function \nspl\a\sorted;
use function \nspl\op\propertyGetter;
use function \nspl\op\methodCaller;

// Sort by property value
$sortedByWeight = sorted($objects, propertyGetter('weight'));

// Or sort by result of method call
$sortedByWeight = sorted($objects, methodCaller('getWeight'));

如果您想在PHP中探索lambda样式函数的完整(可怕)范围,请参阅: http://docs.php.net/manual/en/function。创建-function.php

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top