是的,我已经搜索并尝试了许多技术,但似乎没有任何工作。这是我的阵列:
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');
但那没用。
有什么想法吗?
答案 0 :(得分:10)
你几乎是对的,但是$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
)
)
答案 1 :(得分:3)
usort($array, function($a, $b) {
return strcmp($a->name, $b->name);
});
答案 2 :(得分:0)
您应该使用usort ...
因此,您定义了一个比较两个对象的函数(通过名称字段),然后在数组上运行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);
希望有所帮助!
本