この配列を "order"キーの値でソートするにはどうすればいいですか?値は現在連続していますが、必ずしもそうではありません。
Array
(
[0] => Array
(
[hashtag] => a7e87329b5eab8578f4f1098a152d6f4
[title] => Flower
[order] => 3
)
[1] => Array
(
[hashtag] => b24ce0cd392a5b0b8dedc66c25213594
[title] => Free
[order] => 2
)
[2] => Array
(
[hashtag] => e7d31fc0602fb2ede144d18cdffd816b
[title] => Ready
[order] => 1
)
)
usort を試してください。まだPHP 5.2以前の場合は、まずソート関数を定義する必要があります。
function sortByOrder($a, $b) {
return $a['order'] - $b['order'];
}
usort($myArray, 'sortByOrder');
PHP 5.3以降では、無名関数を使用できます。
usort($myArray, function($a, $b) {
return $a['order'] - $b['order'];
});
そして最後にPHP 7を使うと 宇宙船演算子 を使うことができます。
usort($myArray, function($a, $b) {
return $a['order'] <=> $b['order'];
});
これを多次元ソートに拡張するには、最初のものがゼロの場合は2番目/ 3番目のソート要素を参照してください。これをサブ要素のソートにも使用できます。
usort($myArray, function($a, $b) {
$retval = $a['order'] <=> $b['order'];
if ($retval == 0) {
$retval = $a['suborder'] <=> $b['suborder'];
if ($retval == 0) {
$retval = $a['details']['subsuborder'] <=> $b['details']['subsuborder'];
}
}
return $retval;
});
キーの関連付けを保持する必要がある場合は、マニュアルのuasort()
を使用してください - 配列ソート関数の比較を参照
function aasort (&$array, $key) {
$sorter=array();
$ret=array();
reset($array);
foreach ($array as $ii => $va) {
$sorter[$ii]=$va[$key];
}
asort($sorter);
foreach ($sorter as $ii => $va) {
$ret[$ii]=$array[$ii];
}
$array=$ret;
}
aasort($your_array,"order");
私はこの機能を使用します。
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($array, 'order');
私は通常 usort を使い、自分自身の比較関数を渡します。この場合、それはとても簡単です:
function compareOrder($a, $b)
{
return $a['order'] - $b['order'];
}
usort($array, 'compareOrder');
$sort = array();
$array_lowercase = array_map('strtolower', $array_to_be_sorted);
array_multisort($array_lowercase, SORT_ASC, SORT_STRING, $alphabetically_ordered_array);
これは大文字と小文字の両方のアルファベットを扱います。
これを達成するための1つのアプローチは次のようになります
$new = [
[
'hashtag' => 'a7e87329b5eab8578f4f1098a152d6f4',
'title' => 'Flower',
'order' => 3,
],
[
'hashtag' => 'b24ce0cd392a5b0b8dedc66c25213594',
'title' => 'Free',
'order' => 2,
],
[
'hashtag' => 'e7d31fc0602fb2ede144d18cdffd816b',
'title' => 'Ready',
'order' => 1,
],
];
$keys = array_column($new, 'order');
$result = array_multisort($keys, SORT_ASC, $new);
結果:
Array
(
[0] => Array
(
[hashtag] => e7d31fc0602fb2ede144d18cdffd816b
[title] => Ready
[order] => 1
)
[1] => Array
(
[hashtag] => b24ce0cd392a5b0b8dedc66c25213594
[title] => Free
[order] => 2
)
[2] => Array
(
[hashtag] => a7e87329b5eab8578f4f1098a152d6f4
[title] => Flower
[order] => 3
)
)
"title"キーの値で配列をソートするには、次のようにします。
uasort($myArray, function($a, $b) {
return strcmp($a['title'], $b['title']);
});
strcmp 文字列を比較します。
uasort() は配列キーを定義どおりに維持します。
最も柔軟な方法は、この方法を使用することです。
Arr::sortByKeys(array $array, $keys, bool $assoc = true): array
これが理由です:
任意のキーでソートできます('key1.key2.key3'
または['k1', 'k2', 'k3']
のようにネストされている)
連想配列と非連想配列の両方で機能します($assoc
フラグ)
参照を使用しない - 新しいソート済み配列を返す
あなたの場合はそれは同じくらい簡単でしょう:
$sortedArray = Arr::sortByKeys($array, 'order');
このメソッドは このライブラリ の一部です。
Array_multisort()、array_map()を使用します
array_multisort(array_map(function($element) {
return $element['order'];
}, $array), SORT_ASC, $array);
print_r($array);
それを直視しましょう:phpには、あらゆる配列ソートシナリオを適切に処理するための、すぐに使える単純な関数はありません。
このルーチンは直感的に理解できます。つまり、デバッグとメンテナンスが高速になります。
// automatic population of array
$tempArray = array();
$annotations = array();
// ... some code
// SQL $sql retrieves result array $result
// $row[0] is the ID, but is populated out of order (comes from
// multiple selects populating various dimensions for the same DATE
// for example
while($row = mysql_fetch_array($result)) {
$needle = $row[0];
arrayIndexes($needle); // create a parallel array with IDs only
$annotations[$needle]['someDimension'] = $row[1]; // whatever
}
asort($tempArray);
foreach ($tempArray as $arrayKey) {
$dataInOrder = $annotations[$arrayKey]['someDimension'];
// .... more code
}
function arrayIndexes ($needle) {
global $tempArray;
if (!in_array($needle,$tempArray)) {
array_Push($tempArray,$needle);
}
}