PHP 配列のソートキー名は変更されません。
PHP プログラミングでは、配列をソートする必要があることがよくあります。 PHP には、配列要素をさまざまな方法で並べ替える、sort()、asort()、ksort() などの多くの配列並べ替え関数が用意されています。ただし、これらの関数はデフォルトで配列キーの順序を変更します。配列キーの順序を保持したい場合はどうすればよいでしょうか?この記事ではいくつかの方法を紹介します。
- uksort() 関数を使用する
uksort() 関数は、PHP の非常に強力な関数です。これを使用すると、並べ替え関数を自分で定義し、指定した順序に従って並べ替えることができます。メソッド。配列はソートされます。 uksort() 関数の使用法は次のとおりです。
bool uksort(array &$array, callable $cmp_function)
このうち、$array は並べ替える配列、$cmp_function はカスタム 並べ替え関数です。
カスタム ソート関数では、2 つのパラメーター $a と $b を使用して 2 つの配列要素を比較し、ソートされた結果を返すことができます。 $a が $b より前にある場合は 0 より小さい整数を返します。$a が $b より前にある場合は 0 より大きい整数を返します。$a と $b が等しい場合は 0 を返します。
以下はサンプル コードです:
<?php function my_sort($a, $b) { if ($a == $b) { return 0; } return ($a > $b) ? 1 : -1; } $array = array( 'c' => 1, 'a' => 2, 'b' => 3, ); uksort($array, 'my_sort'); print_r($array); ?>
上記のコードは次のように出力します:
Array ( [c] => 1 [a] => 2 [b] => 3 )
ご覧のとおり、配列要素のキー名は変更されていません。このうち、my_sort()関数はキー名の大小関係に基づいて比較します。
- ksort() 関数を使用してキー名を保存する
ksort() 関数は、キー名で並べ替えるために PHP で一般的に使用される関数です。 sort() や asort() とは異なり、ksort() はキー名を変更せずに配列要素の順序のみを変更します。
ただし、いくつかのテクニックを使用して元のキー名を保存することもできます。具体的な方法は、まずキー名と対応する値を新しい配列に格納し、次に新しい配列を並べ替え、最後に並べ替えた値を元の配列に再割り当てします。サンプル コードは次のとおりです。
<?php $array = array( 'c' => 1, 'a' => 2, 'b' => 3, ); $tmp_array = array(); foreach ($array as $key => $value) { $tmp_array[$key] = $value; } ksort($tmp_array); $new_array = array(); foreach ($tmp_array as $key => $value) { $new_array[$key] = $value; } $array = $new_array; print_r($array); ?>
上記のコードは次のように出力します。
Array ( [c] => 1 [a] => 2 [b] => 3 )
ご覧のとおり、配列要素のキー名は変更されていません。ただし、この方法では、元のキー名を保存するために追加の配列を使用する必要があるため、配列要素の数が多い場合にはメモリの問題が発生する可能性があります。
- asort() 関数を使用してキー名を保存します
ksort() と同様に、asort() 関数も値で並べ替えることができますが、配列要素を変更します。
同様に、いくつかのテクニックを使用して元のキー名を保存することもできます。具体的な方法は、まずキー名と対応する値を新しい配列に格納し、次に新しい配列を並べ替え、最後に並べ替えた値を元の配列に再割り当てします。サンプル コードは次のとおりです。
<?php $array = array( 'c' => 1, 'a' => 2, 'b' => 3, ); $tmp_array = array(); foreach ($array as $key => $value) { $tmp_array[$key] = $value; } asort($tmp_array); $new_array = array(); foreach ($tmp_array as $key => $value) { $new_array[$key] = $value; } $array = $new_array; print_r($array); ?>
上記のコードは次のように出力します。
Array ( [c] => 1 [a] => 2 [b] => 3 )
ご覧のとおり、配列要素のキー名は変更されていません。同様に、この方法でも元のキー名を保存するために追加の配列を使用する必要があるため、メモリの問題が発生する可能性があります。
要約すると、上記の 3 つの方法は配列キー名の順序を保持でき、特定の状況に応じて選択できます。ただし、配列内に重複したキー名がある場合、ソート後にキー名が欠落する可能性があるため、これは特定の状況に応じて処理する必要があることに注意してください。
以上がPHP 配列のソートキー名は変更されません。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











この記事では、効率的なPHPアレイ重複排除について説明します。 Array_unique()などの組み込み関数をカスタムハッシュマップアプローチと比較し、配列のサイズとデータ型に基づいてパフォーマンスのトレードオフを強調します。 最適な方法は、プロビリに依存します

この記事では、Keyの一意性を使用してPHPアレイ重複排除について説明します。 直接的な重複除去方法ではありませんが、キーユニークネスを活用することで、キーに値をマッピングして重複を上書きすることにより、一意の値を持つ新しい配列を作成できます。 このAP

この記事では、PHPアレイの重複排除を分析し、素朴なアプローチ(O(n²))のパフォーマンスボトルネックを強調しています。 カスタム関数、splobjectStorage、およびハッシュセットの実装を使用して、array_unique()を使用して効率的な代替案を調査し、達成します

この記事では、RabbitMQとRedisを使用してPHPでメッセージキューを実装する詳細を示します。 それは、それらのアーキテクチャ(AMQP対インメモリ)、機能、および信頼性メカニズム(確認、トランザクション、永続性)を比較します。デザインのベストプラクティス、エラー

この記事では、PSRの推奨事項(PSR-1、PSR-2、PSR-4、PSR-12)に焦点を当てた現在のPHPコーディング基準とベストプラクティスを検証します。 一貫したスタイリング、意味のある命名、EFFを通じてコードの読みやすさと保守性を改善することを強調しています

この記事では、大規模なデータセットのPHPアレイ重力化の最適化について説明します。 Array_unique()、array_flip()、splobjectStorage、事前ソートなどの手法を調べ、効率を比較します。 大規模なデータセットの場合、チャンク、データブを示唆しています

この記事では、PHP拡張機能のインストールとトラブルシューティングの詳細で、PECLに焦点を当てています。 インストール手順(検索、ダウンロード/コンパイル、サーバーの再起動、再起動)、トラブルシューティングテクニック(ログのチェック、インストールの確認、

この記事では、PHPの反射APIについて説明し、クラス、方法、およびプロパティのランタイム検査と操作を可能にします。 一般的なユースケース(ドキュメンテーション生成、ORM、依存関係注入)とパフォーマンスオーバーヘアに対する注意の詳細
