方法: ファイルまたはフォルダーを作成する (C# プログラミング ガイド)
プログラムでコンピューターのフォルダーを作成し、サブフォルダーを作成し、サブフォルダー内のファイルを作成し、ファイルにデータを書き込むことができます。
使用例
public class CreateFileOrFolder
{
static void Main()
{
// Specify a name for your top-level folder.
string folderName = @"c:\Top-Level Folder";
// To create a string that specifies the path to a subfolder under your
// top-level folder, add a name for the subfolder to folderName.
string pathString = System.IO.Path.Combine(folderName, "SubFolder");
// You can write out the path name directly instead of using the Combine
// method. Combine just makes the process easier.
string pathString2 = @"c:\Top-Level Folder\SubFolder2";
// You can extend the depth of your path if you want to.
//pathString = System.IO.Path.Combine(pathString, "SubSubFolder");
// Create the subfolder. You can verify in File Explorer that you have this
// structure in the C: drive.
// Local Disk (C:)
// Top-Level Folder
// SubFolder
System.IO.Directory.CreateDirectory(pathString);
// Create a file name for the file you want to create.
string fileName = System.IO.Path.GetRandomFileName();
// This example uses a random string for the name, but you also can specify
// a particular name.
//string fileName = "MyNewFile.txt";
// Use Combine again to add the file name to the path.
pathString = System.IO.Path.Combine(pathString, fileName);
// Verify the path that you have constructed.
Console.WriteLine("Path to my file: {0}\n", pathString);
// Check that the file doesn't already exist. If it doesn't exist, create
// the file and write integers 0 - 99 to it.
// DANGER: System.IO.File.Create will overwrite the file if it already exists.
// This could happen even with random file names, although it is unlikely.
if (!System.IO.File.Exists(pathString))
{
using (System.IO.FileStream fs = System.IO.File.Create(pathString))
{
for (byte i = 0; i < 100; i++)
{
fs.WriteByte(i);
}
}
}
else
{
Console.WriteLine("File \"{0}\" already exists.", fileName);
return;
}
// Read and display the data from your file.
try
{
byte[] readBuffer = System.IO.File.ReadAllBytes(pathString);
foreach (byte b in readBuffer)
{
Console.Write(b + " ");
}
Console.WriteLine();
}
catch (System.IO.IOException e)
{
Console.WriteLine(e.Message);
}
// Keep the console window open in debug mode.
System.Console.WriteLine("Press any key to exit.");
System.Console.ReadKey();
}
// Sample output:
// Path to my file: c:\Top-Level Folder\SubFolder\ttxvauxe.vv0
//0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
//30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
// 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 8
//3 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
}
フォルダーが既に存在していた場合、CreateDirectory は何も実行せず、例外はスローされません。ただし、File.Create は新しいファイルによって上書きされます。例は、既存のファイルが置換されることを防ぐために if-else のステートメントを使用します。
次の例の変更を加えることで、特定の名前のファイルが既に存在するかどうかに基づいて異なる結果を指定できます。このようなファイルが存在しない場合は、1 種類を作成します。このようなファイルがある場合、コードはそのファイルにデータを追加します。
ランダムなファイル名ではなくを指定します。
// Comment out the following line. //string fileName = System.IO.Path.GetRandomFileName(); // Replace that line with the following assignment. string fileName = "MyNewFile.txt";
次のコードの using のステートメントで if-else のステートメントに置き換えます。
using (System.IO.FileStream fs = new System.IO.FileStream(pathString, FileMode.Append)) { for (byte i = 0; i < 100; i++) { fs.WriteByte(i); } }
例をデータをファイルに追加されることを確認するたび数回実行します。
ユーザーが行うことができる FileMode の詳細の値では、FileModeを参照してください。
次の条件を満たす場合は、例外が発生する可能性があります。
フォルダー名が不適切である場合。たとえば、不正な文字が含まれている場合や、空白だけの場合などがその例です (ArgumentException クラス)。有効なパス名を作成するには Path のクラスを使用します。
作成するフォルダーの親フォルダーが読み取り専用である場合 (IOException クラス)。
フォルダー名が null である場合 (ArgumentNullException クラス)。
フォルダー名が長すぎる場合 (PathTooLongException クラス)。
フォルダー名がコロン (":") だけである場合 (PathTooLongException クラス)。
セキュリティ
SecurityException クラスのインスタンスが部分信頼の状況でスローされることがあります。
フォルダーを作成するアクセス許可がない UnauthorizedAccessException の例は、クラスのインスタンスがスローされます。