6

基本上我有如下设置:

Array ( 
[0] => Array ( [0] => stdClass Object ( [nid] => 1 [title] => title1 [uid] => 1 [parent] => 0 [weight] => -15 [name] => name1 [value] => 0 )
               [1] => stdClass Object ( [nid] => 2 [title] => title2 [uid] => 1 [parent] => 0 [weight] => -7 [name] => name2 [value] => 100 )
               [2] => stdClass Object ( [nid] => 3 [title] => title3 [uid] => 2 [parent] => 0 [weight] => -1 [name] => name3 [value] => 0 )
               [3] => stdClass Object ( [nid] => 4 [title] => title4 [uid] => 2 [parent] => 0 [weight] => 1 [name] => name4 [value] => 80 )
              )
  )

我需要的是一种通过对象中的 [value] 键对父数组中的所有数组进行排序的方法。我已经用 usort 和不同的方法尝试了大约 2 天,但我似乎无法理解它。[value] 键的范围从 0 到 100,我需要按降序排序的所有数组(即:100 到 0)。

4

5 回答 5

14

使用usort

function cmp($a, $b) {
  if ($a->value == $b->value) {
    return 0;
  } else {
    return $a->value < $b->value ? 1 : -1; // reverse order
  }
}

usort($arr, 'cmp');
于 2009-01-05T23:36:17.850 回答
4

100% 从本页的第一个答案中窃取。 http://us.php.net/manual/en/function.array-multisort.php
但这就是我想要的。

对对象数组进行多排序:

example object [$object with array of objects]: (class: test) 
---------------------------------- 

test Object (
  [Artikel] => Array (
      [0] => test Object (
            [id] => 1
            [title] => CCCC
         )
      [1] => test Object (
            [id] => 2
            [title] => AAAA
         )
      [2] => test Object (
            [id] => 3
            [title] => DDDD
         )
      [3] => test Object (
            [id] => 4
            [title] => BBBB
         )
   )
)

---------------------------------- 

Simple PHP function: sort_arr_of_obj()

<?php 
// -------------------------------------- 

/* 
* -------- function arguments -------- 
*   $array ........ array of objects
*   $sortby ....... the object-key to sort by
*   $direction ... 'asc' = ascending
* --------
*/

function sort_arr_of_obj($array, $sortby, $direction='asc') {

    $sortedArr = array();
    $tmp_Array = array();

    foreach($array as $k => $v) {
        $tmp_Array[] = strtolower($v->$sortby);
    }

    if($direction=='asc'){
        asort($tmp_Array);
    }else{
        arsort($tmp_Array);
    }

    foreach($tmp_Array as $k=>$tmp){
        $sortedArr[] = $array[$k];
    }

    return $sortedArr;

}


// -------------------------------------- 
?>

example call: 
---------------------------------- 

<?php 

$sorted->Artikel = sort_arr_of_obj($object->Artikel,'title','asc');

?>

example result: $sorted (class: test) 
---------------------------------- 

test Object (
  [Artikel] => Array (
      [0] => test Object (
            [id] => 2
            [title] => AAAA
         )
      [1] => test Object (
            [id] => 4
            [title] => BBBB
         )
      [2] => test Object (
            [id] => 1
            [title] => CCCC
         )
      [3] => test Object (
            [id] => 3
            [title] => DDDD
         )

   )
)
于 2012-12-09T22:31:54.327 回答
3

一种方法是将值数组与对象数组分开,从而创建两个数组。然后,您可以使用 array_multisort 根据另一个数组对对象数组进行排序。这是一个例子:

<?php
$array1 = $objectvalues
$array2 = array(ObjectWithNid1, ObjectWithNid2, ObjectWithNid3, ObjectWithNid4);
array_multisort($array1, $array2);
?>

您可以使用 foreach 循环一次数组并使用相应的 [value] 键创建一个新数组:

<?php
foreach( $arraywithobjects as $obj )
{
    $objectvalues[] = $obj->getValue();
}
?>

这将获取对象的值并将其插入到另一个数组中,您可以将其与多重排序一起使用。

最后,您的代码将如下所示:

<?php
foreach( $arraywithobjects as $obj )
{
    $objectvalues[] = $obj->getValue();
}
$array2 = array(ObjectWithNid1, ObjectWithNid2, ObjectWithNid3, ObjectWithNid4);
array_multisort($objectvalues, $array2);
?>

array_multisort 字段中的第一个数组应该是您用来对第二个数组进行排序的数组。

您还可以为此添加其他排序方法。你可以在这里阅读它们:链接文本

于 2009-06-18T14:37:03.770 回答
1
function cmp($a, $b) {
    return $b->value - $a->value;
}

$ary[0] = usort($ary[0], "cmp");

为了根据简单值或键以外的任何内容对数组进行排序,您需要使用该usort函数并提供您自己的比较。比较函数必须定义为,如果$a出现在 之前$b,则返回正值,如果出现在之前,则返回负值$b$a如果它们相等,则返回零)。当您基于数值进行比较并且想要反向排序时,最简单的方法是$a从 的值中减去 的“值” $b

于 2009-01-05T23:39:52.587 回答
0

我可能是错的,但我相信我使用 asort()(或 asort())做了类似的事情。它在一个搜索功能中,我需要对一个填充了索引和时间戳的二维数组进行排序。

我不确定它是否适用于您的情况,我很久以前就这样做了。也许它会让你开始,但祝你好运。

于 2009-01-05T23:36:17.773 回答