パスまたはファイル名の拡張子を別の拡張子に置き換えるにはChangeExtensionメソッドを使います。 元のパス・ファイル名に拡張子がない場合は拡張子が追加され、ピリオドが二つ以上あるファイル名の場合は一番最後のピリオド以降が置き換えられます。
ファイル名部分のうち、どの部分を拡張子と判断するかの基準はGetExtensionメソッドと同様です。 このため、UNIX系OSで隠しファイルとして扱われるドットファイル(dot file)では、ピリオドが一つだけ含まれる場合はファイル名全体が拡張子と判断され、ファイル名に対する置換が行われることになります。 この他、拡張子に関する注意点についてはGetExtensionメソッドを参照してください。
置き換える拡張子に空の文字列(String.Empty)を指定した場合、ピリオドだけの拡張子に置換されます。 一方、null
/Nothing
を指定した場合は、ピリオドも含めて拡張子が削除されます。
特に、ピリオドが一つだけ含まれるドットファイルの場合、ピリオドだけのファイル名.
、あるいは長さ0のファイル名に変換されることになるため、注意が必要です。
Path.ChangeExtensionメソッドでファイル名から拡張子を削除する
using System;
using System.IO;
class Sample {
static void Main()
{
foreach (var path in new[] {
@"E:\dir\subdir\file.txt", // 絶対パス (Windows形式)
@"/dir/subdir/file.txt", // 絶対パス (UNIX形式)
@".\dir\subdir\file.txt", // 相対パス (Windows形式)
@"./dir/subdir/file.txt", // 相対パス (UNIX形式)
@"file.txt", // ファイル名のみのパス
@"file", // 拡張子のないファイル名
@"file.txt.bak", // ピリオドを二つ以上含むファイル名
@"file.", // ピリオドで終わるファイル名
@".file", // ピリオドで始まるファイル名
}) {
Console.WriteLine("path = {0}", path);
// パスのファイル名から、ピリオドを残して拡張子を削除する
Console.WriteLine("change ext (empty) => {0}", Path.ChangeExtension(path, string.Empty));
// パスのファイル名から、ピリオドも含めて拡張子を削除する
Console.WriteLine("change ext (null) => {0}", Path.ChangeExtension(path, null));
Console.WriteLine();
}
}
}
実行結果
path = E:\dir\subdir\file.txt change ext (empty) => E:\dir\subdir\file. change ext (null) => E:\dir\subdir\file path = /dir/subdir/file.txt change ext (empty) => /dir/subdir/file. change ext (null) => /dir/subdir/file path = .\dir\subdir\file.txt change ext (empty) => .\dir\subdir\file. change ext (null) => .\dir\subdir\file path = ./dir/subdir/file.txt change ext (empty) => ./dir/subdir/file. change ext (null) => ./dir/subdir/file path = file.txt change ext (empty) => file. change ext (null) => file path = file change ext (empty) => file. change ext (null) => file path = file.txt.bak change ext (empty) => file.txt. change ext (null) => file.txt path = file. change ext (empty) => file. change ext (null) => file path = .file change ext (empty) => . change ext (null) =>
実行結果
path = E:\dir\subdir\file.txt change ext (empty) => E:\dir\subdir\file. change ext (null) => E:\dir\subdir\file path = /dir/subdir/file.txt change ext (empty) => /dir/subdir/file. change ext (null) => /dir/subdir/file path = .\dir\subdir\file.txt change ext (empty) => .\dir\subdir\file. change ext (null) => .\dir\subdir\file path = ./dir/subdir/file.txt change ext (empty) => ./dir/subdir/file. change ext (null) => ./dir/subdir/file path = file.txt change ext (empty) => file. change ext (null) => file path = file change ext (empty) => file. change ext (null) => file path = file.txt.bak change ext (empty) => file.txt. change ext (null) => file.txt path = file. change ext (empty) => file. change ext (null) => file path = .file change ext (empty) => . change ext (null) =>