方法: テキスト ファイルからデータを読み取る (Visual Basic)

ReadAllText オブジェクトの My.Computer.FileSystem メソッドを使用すると、テキスト ファイルを読み取ることができます。 ファイルの内容が ASCII や UTF-8 などのエンコーディングを使用している場合、ファイル エンコーディングを指定できます。

読み取るファイルで拡張文字が使用されている場合、ファイル エンコーディングを指定する必要があります。

Note

ファイルから 1 回に 1 行のテキストを読み取るには、OpenTextFileReader オブジェクトの My.Computer.FileSystem メソッドを使用します。 OpenTextFileReader メソッドが StreamReader オブジェクトを返します。 ReadLine オブジェクトの StreamReader メソッドを使用して、ファイルから 1 回に 1 行を読み取ることができます。 EndOfStream オブジェクトの StreamReader メソッドを使用して、ファイルの最後かどうかをテストできます。

テキスト ファイルを読み取るには

ReadAllText オブジェクトの My.Computer.FileSystem メソッドを使用して、ファイルのパスを指定し、テキスト ファイルの内容を文字列に読み取ります。 次の例は、test.txt の内容を文字列に読み取り、メッセージ ボックスに表示します。

Dim fileReader As String
fileReader = My.Computer.FileSystem.ReadAllText("C:\test.txt")
MsgBox(fileReader)

エンコードされているテキスト ファイルを読み取るには

ReadAllText オブジェクトの My.Computer.FileSystem メソッドを使用して、ファイルのパスとファイル エンコードの種類を指定し、テキスト ファイルの内容を文字列に読み取ります。 次の例は、UTF32 ファイルである test.txt の内容を文字列に読み取り、メッセージ ボックスに表示します。

Dim fileReader As String
fileReader = My.Computer.FileSystem.ReadAllText("C:\test.txt",
   System.Text.Encoding.UTF32)
MsgBox(fileReader)

信頼性の高いプログラミング

次の条件を満たす場合は、例外が発生する可能性があります。

  • パスが無効である場合。1) 長さが 0 の文字列である、2) 空白だけが含まれている、3) 無効な文字が含まれている、4) デバイス パスである、のいずれかの理由が考えられる (ArgumentException)。

  • パスが Nothing であるため、有効でない (ArgumentNullException)

  • ファイルが存在しない (FileNotFoundException)。

  • 他のプロセスがファイルを使用しているか、または I/O エラーが発生した (IOException)。

  • パスがシステムで定義されている最大長を超えている (PathTooLongException)。

  • パス内のファイル名またはディレクトリ名にコロン (:) が含まれているか、または形式が無効である (NotSupportedException)

  • 文字列をバッファーに書き込むための十分なメモリがない (OutOfMemoryException)

  • ユーザーがパスを参照するのに必要なアクセス許可がない (SecurityException)

ファイル名からファイルの内容を判断しないでください。 たとえば、Form1.vb というファイルは Visual Basic のソース ファイルではない可能性もあります。

アプリケーションでデータを使用する前に、入力をすべて検証してください。 ファイルの内容が予想どおりでないことがあり、ファイルの内容を読み取るメソッドが失敗する可能性があります。

関連項目