2

我试图通过以下两种方式对数组的元素进行排序:

  • 按密钥长度排序(最小的应该在前) -见这里
  • 最大值应该先行

要按密钥长度排序,我使用以下命令:

    function sortByLength($a,$b){
      if($a == $b) return 0;
      return (strlen($a) < strlen($b) ? -1 : 1);
    }

    uasort($deals_tag,'sortByLength');

数组是这样排序的:

Array
(
 [/merchantProductFeed] => 1
 [/merchantProductFeed/merchant] => 1
 [/merchantProductFeed/merchant/prod/text] => 158
 [/merchantProductFeed/merchant/prod] => 158
)

我希望它像这样排序:

Array
(
 [/merchantProductFeed/merchant/prod] => 158
 [/merchantProductFeed/merchant/prod/text] => 158
 [/merchantProductFeed] => 1
 [/merchantProductFeed/merchant] => 1
)

请注意,首先数组按键长度排序,然后按最大值排序。

我不知道该怎么做。

任何帮助将不胜感激!谢谢!

4

2 回答 2

1

更新:您可以使用array_mulitsort。尝试

$k= array();
$v = array();

foreach($deals_tag as $key => $value){
    $k[] = $key;
    $v[] = $value;
}

array_multisort($v, SORT_DESC, $k, SORT_ASC,  $deals_tag);
于 2012-07-29T05:24:01.653 回答
1

我知道这可能有点开销,但排序事物的另一种方法是使用(临时)数据库,如果我需要一些“硬核”排序,我会亲自使用它,所以这里是......

<?php
$p = new PDO("sqlite::memory:");
$p->exec("CREATE TABLE a (k varchar(255),v int)");

$p->exec("INSERT INTO a (k,v) VALUES('/merchantProductFeed',1)");
$p->exec("INSERT INTO a (k,v) VALUES('/merchantProductFeed/merchant',1)");
$p->exec("INSERT INTO a (k,v) VALUES('/merchantProductFeed/merchant/prod/text',158)");
$p->exec("INSERT INTO a (k,v) VALUES('/merchantProductFeed/merchant/prod',158)");

$st=$p->query("SELECT * FROM a ORDER BY length(k) DESC,v DESC");
print_r($st->fetchAll());
?>

我不知道你的字符串有多长,在这个例子中我使用 varchar(255) 如果它更长你应该使用 TEXT。

于 2012-07-29T05:52:38.620 回答