4

是的,我已经搜索并尝试了许多技术,但似乎没有任何效果。这是我的数组:

Array
(
    [0] => stdClass Object
        (
            [id] => 119
            [name] => Business3
            [start_date] => 1338789600
            [end_date] => 1354604400
        )

    [1] => stdClass Object
        (
            [id] => 153
            [name] => Business1
            [start_date] => 1338962400
            [end_date] => 1370498400
        )

    [2] => stdClass Object
        (
            [id] => 135
            [name] => Business2  
            [start_date] => 1339653600
            [end_date] => 1356937200
        )
)

我基本上想按名称键对其进行排序,但是我在 Stackoverflow 上尝试过的每个功能似乎都不起作用,例如,我得到一个没有错误的空白页。

我试过这个:

function array_sort_by_column(&$arr, $col, $dir = SORT_ASC) {
    $sort_col = array();
    foreach ($arr as $key=> $row) {
        $sort_col[$key] = $row[$col];
    }

    array_multisort($sort_col, $dir, $arr);
}

array_sort_by_column(json_decode(json_encode($businesses), true), 'name');

但这没有用。

有任何想法吗?

4

3 回答 3

11

您几乎是对的,但$row[$col]尝试像数组一样访问对象。你想要类似的东西$row->{$col}。这是一个更简单的工作示例:

$db = array(
  0 => (object) array('name' => 'Business3'),
  1 => (object) array('name' => 'Business2'),
  2 => (object) array('name' => 'Business1')
);

$col  = 'name';
$sort = array();
foreach ($db as $i => $obj) {
  $sort[$i] = $obj->{$col};
}

$sorted_db = array_multisort($sort, SORT_ASC, $db);

print_r($db);

输出:

Array
(
    [0] => stdClass Object
        (
            [name] => Business1
        )

    [1] => stdClass Object
        (
            [name] => Business2
        )

    [2] => stdClass Object
        (
            [name] => Business3
        )

)
于 2012-06-13T21:39:22.910 回答
3
usort($array, function($a, $b) {
    return strcmp($a->name, $b->name);
});
于 2015-01-18T14:48:01.420 回答
0

你应该使用usort ...

因此,您定义了一个比较两个对象的函数(通过 name 字段),然后在数组上运行 usort,将函数作为第二个参数传入。

像这样的东西:

function cmp($a, $b)
{
    if ($a["name"] == $b["name"]) {
        return 0;
    }
    return ($a["name"] < $b["name"]) ? -1 : 1;
}

usort ($my_array, "cmp");
var_dump($my_array);

希望有帮助!

于 2012-06-13T21:38:25.977 回答