Webエンジニア向けプログラミング解説動画をYouTubeで配信中!
▶ チャンネル登録はこちら

【PHP8.x】ArrayIterator::natsort()メソッドの使い方

natsortメソッドの使い方について、初心者にもわかりやすく解説します。

作成日: 更新日:

基本的な使い方

natsortメソッドは、ArrayIteratorオブジェクトが内部で保持している配列を、自然順アルゴリズムを用いてソートを実行するメソッドです。このソート方法は、文字列に含まれる数値を文字としてではなく数値の大きさとして比較するため、人間が直感的に並び替える順序と同じ結果を得られます。例えば、「img2.png」、「img10.png」、「img1.png」という要素を持つ配列をソートする場合、通常の文字列ソートでは「img1.png」、「img10.png」、「img2.png」の順になりますが、natsortメソッドを使用すると「img1.png」、「img2.png」、「img10.png」という期待通りの順序に並び替えられます。このメソッドは、元の配列のキーと値の関連性を維持したままソートを行います。また、ソートはイテレータが指す配列そのものを直接変更する破壊的な操作であり、メソッド自体の返り値はありません。ファイル名やバージョン番号など、アルファベットと数字が混在したデータを直感的な順序で扱いたい場合に非常に便利なメソッドです。

構文(syntax)

1<?php
2// 元となる配列を定義します
3$array = ['img12.png', 'img10.png', 'img2.png', 'img1.png'];
4
5// 配列からArrayIteratorオブジェクトを作成します
6$iterator = new ArrayIterator($array);
7
8// natsort()メソッドを呼び出して、"自然順"で要素をソートします
9$iterator->natsort();
10
11// ソート後のイテレータの内容をループして表示します
12foreach ($iterator as $key => $value) {
13    echo "{$key}: {$value}\n";
14}
15?>

引数(parameters)

引数なし

引数はありません

戻り値(return)

戻り値なし

戻り値はありません

サンプルコード

ArrayIterator::natsortで多次元配列の要素を自然順ソートする

1<?php
2
3/**
4 * ArrayIterator::natsort を使用して、多次元配列の各サブ配列の要素を自然順序でソートします。
5 *
6 * この関数は、システムエンジニアを目指す初心者向けに、
7 * ArrayIterator クラスの natsort メソッドの具体的な使い方を示します。
8 * natsort は、"自然順序" (例えば、"img10.png" が "img2.png" の後に来るように) で文字列をソートするのに役立ちます。
9 *
10 * @return void
11 */
12function sortMultidimensionalArrayElementsNaturally(): void
13{
14    // 多次元配列の例: 各カテゴリ(キー)が、ファイル名のリスト(値)を持つ
15    $multidimensionalArray = [
16        'images' => [
17            'image10.png',
18            'image2.png',
19            'image1.png',
20            'image_thumb.png',
21        ],
22        'documents' => [
23            'document_final.pdf',
24            'document10.pdf',
25            'document2.pdf',
26            'document1.pdf',
27        ],
28        'archive' => [
29            'data_v10.zip',
30            'data_v2.zip',
31            'data_v1.zip',
32        ],
33    ];
34
35    echo "--- ソート前の多次元配列 ---\n";
36    foreach ($multidimensionalArray as $category => $items) {
37        echo sprintf("カテゴリ '%s': %s\n", $category, implode(', ', $items));
38    }
39    echo "\n";
40
41    $sortedMultidimensionalArray = [];
42
43    // 多次元配列の各サブ配列をループ処理します。
44    // ArrayIterator::natsort は、ArrayIterator がラップしている単一の配列の値をソートするため、
45    // 各サブ配列に対して個別に適用する必要があります。
46    foreach ($multidimensionalArray as $category => $items) {
47        // 現在のサブ配列を ArrayIterator でラップします。
48        $iterator = new ArrayIterator($items);
49
50        // natsort メソッドを呼び出して、ArrayIterator 内の配列の要素を自然順序でソートします。
51        // このメソッドは元の配列を直接変更し、戻り値はありません (void)。
52        $iterator->natsort();
53
54        // ソートされた配列を取得して、新しい多次元配列に格納します。
55        $sortedMultidimensionalArray[$category] = $iterator->getArrayCopy();
56    }
57
58    echo "--- ArrayIterator::natsort でソート後の多次元配列 ---\n";
59    foreach ($sortedMultidimensionalArray as $category => $items) {
60        echo sprintf("カテゴリ '%s': %s\n", $category, implode(', ', $items));
61    }
62}
63
64// 関数を実行して結果を表示します。
65sortMultidimensionalArrayElementsNaturally();

PHPのArrayIterator::natsortメソッドは、ArrayIteratorクラスのインスタンスが保持する配列の要素を「自然順序」でソートするための機能です。PHP 8で利用できます。

このメソッドは引数を必要とせず、また戻り値もありません。代わりに、ArrayIteratorオブジェクト内部で管理している配列の要素を直接変更(ソート)します。自然順序とは、例えば"file2.txt"の次に"file10.txt"が来るように、文字列内の数値部分を適切に考慮して並べ替える方式を指します。これは、"file10.txt"が"file2.txt"の前に来てしまうような通常の文字列ソートとは異なります。

提供されたサンプルコードは、多次元配列内の各サブ配列の要素を自然順序でソートする具体的な例を示しています。まず、対象となるサブ配列をArrayIteratorのコンストラクタに渡してインスタンスを作成します。次に、そのArrayIteratorインスタンスに対してnatsort()メソッドを呼び出すことで、内部の配列が自然順序でソートされます。ソートされた結果は、getArrayCopy()メソッドを使って取得し、新しい多次元配列として構築し直しています。この方法は、多次元配列の各レベルのソートにnatsortを適用する際の効果的なアプローチを示しています。

ArrayIterator::natsortは、多次元配列全体ではなく、ArrayIteratorがラップする単一の配列を自然順でソートします。そのため、多次元配列の各サブ配列をソートするには、サブ配列ごとにArrayIteratorを作成し、個別にnatsortを適用する必要があります。このメソッドはソート結果を戻り値として返さず、ArrayIterator内部の配列が直接変更されますので、ソート後の配列を取得する際はgetArrayCopy()を使用します。natsortは、"image2.png"、"image10.png"のように数字を含む文字列を、人間が直感的に理解しやすい自然な順序でソートする際に特に有用であり、通常の辞書順ソートとは異なる振る舞いをすることを知っておくと、意図しないソートを防ぐことができます。

関連コンテンツ