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

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

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

作成日: 更新日:

基本的な使い方

getExtensionメソッドは、DirectoryIteratorクラスのインスタンスが指し示すファイルのエントリから、そのファイルの拡張子を取得するメソッドです。このメソッドは、ファイル名の最後のドット(.)以降の文字列を拡張子として返します。例えば、「report.pdf」というファイル名からは「pdf」を、「archive.tar.gz」からは「gz」といった文字列が得られます。拡張子がないファイルの場合や、対象がディレクトリである場合は、空の文字列「''」を返します。また、「.env」のようにドットで始まるファイルの場合には、「env」が拡張子と見なされます。DirectoryIteratorを使ったディレクトリ走査において、ファイルの種類の判別や特定の拡張子を持つファイルだけを選別する際に非常に有用であり、PHP 8でのファイル分類やフィルタリングの基本的な機能として活用できます。

構文(syntax)

1<?php
2$file = new DirectoryIterator(__FILE__);
3$extension = $file->getExtension();
4echo $extension;
5?>

引数(parameters)

引数なし

引数はありません

戻り値(return)

string

このメソッドは、対象となるファイルの名前の拡張子(例: "txt"、"php")を文字列で返します。拡張子がない場合は空文字列を返します。

サンプルコード

PHP DirectoryIteratorでファイル拡張子を取得する

1<?php
2
3/**
4 * 指定されたディレクトリ内のファイルの拡張子を取得し、表示する関数。
5 *
6 * この関数は DirectoryIterator クラスを使用して指定ディレクトリを走査し、
7 * 各ファイルのエントリから getExtension() メソッドを使って拡張子を取得します。
8 *
9 * @param string $directoryPath 処理対象のディレクトリのパス。
10 *                               例: `.` (カレントディレクトリ) や `/path/to/my/files`
11 */
12function displayFileExtensions(string $directoryPath): void
13{
14    echo "指定ディレクトリ '{$directoryPath}' 内のファイルの拡張子を取得します:\n";
15    echo "--------------------------------------------------\n";
16
17    try {
18        // 指定したディレクトリのイテレータを作成
19        // DirectoryIterator は、ディレクトリ内のファイルやサブディレクトリを反復処理するためのクラスです。
20        $iterator = new DirectoryIterator($directoryPath);
21
22        // ディレクトリ内のエントリを一つずつ処理
23        foreach ($iterator as $fileInfo) {
24            // . や .. (カレントディレクトリと親ディレクトリ) を除外し、かつファイルである場合のみ処理
25            // isFile() は、現在のエントリが通常のファイルである場合に true を返します。
26            if ($fileInfo->isFile()) {
27                // ファイル名を取得
28                $filename = $fileInfo->getFilename();
29
30                // ファイルの拡張子を取得
31                // getExtension() は、パスの最後のドット以降の部分を拡張子として返します。
32                // 拡張子がない場合は空文字列が返されます。
33                $extension = $fileInfo->getExtension();
34
35                // 結果を表示
36                if ($extension === '') {
37                    echo "- ファイル: " . $filename . " (拡張子なし)\n";
38                } else {
39                    echo "- ファイル: " . $filename . ", 拡張子: ." . $extension . "\n";
40                }
41            }
42        }
43    } catch (UnexpectedValueException $e) {
44        // ディレクトリが見つからない、またはアクセス権がない場合のエラーハンドリング
45        echo "エラー: 指定されたディレクトリが見つからないか、アクセスできません。\n";
46        echo "詳細: " . $e->getMessage() . "\n";
47    }
48
49    echo "--------------------------------------------------\n";
50}
51
52// スクリプトがある現在のディレクトリを対象とします。
53// このスクリプトと同じディレクトリに、事前にいくつかのファイル(例: mydocument.txt, photo.jpg, script.php, README)
54// を作成しておくと、さまざまな拡張子の取得結果を確認できます。
55$targetDirectory = __DIR__;
56
57// 関数を呼び出して実行
58displayFileExtensions($targetDirectory);
59
60?>

PHPのDirectoryIterator::getExtensionメソッドは、指定したディレクトリ内のファイルから拡張子を正確に取得するための機能です。このメソッドはDirectoryIteratorクラスに属しており、ディレクトリ内のファイルやサブディレクトリを効率的に反復処理する際に、各ファイルの情報(SplFileInfoオブジェクト)から拡張子を取り出すのに使用されます。

サンプルコードでは、まずDirectoryIteratorを使って指定ディレクトリを走査し、foreachループでファイル情報を一つずつ取り出します。その後、isFile()メソッドで現在のエントリが通常のファイルであるかを確認し、$fileInfo->getExtension()を呼び出すことで、そのファイルの拡張子を文字列として取得しています。このメソッドは引数を必要としません。戻り値はstring型で、ファイルの拡張子を返します。もしファイルに拡張子がない場合は、空の文字列が返されるため、サンプルコードのように拡張子があるかどうかの判定も可能です。この機能は、ファイルの種類を判別して処理を分けたい場合などに大変便利です。

このサンプルコードでは、getExtension() メソッドが拡張子を持たないファイルに対しては空文字列 '' を返します。そのため、拡張子の有無を判断する際は if ($extension === '') のように明示的にチェックすることが重要です。また、DirectoryIterator は指定パスが存在しない、またはアクセスできない場合に UnexpectedValueException をスローするため、try-catch ブロックによる適切なエラーハンドリングが必須です。ファイル名の ... など特殊なエントリは isFile() メソッドで除外されており、これにより意図しない処理を防いでいます。関数に渡すディレクトリパスは、常に安全な値であることを確認してください。

関連コンテンツ