Compartilhar via


Como ler de arquivos de texto no Visual Basic

O ReadAllText método do My.Computer.FileSystem objeto permite que você leia de um arquivo de texto. A codificação de arquivo poderá ser especificada se o conteúdo do arquivo usar uma codificação como ASCII ou UTF-8.

Se você estiver lendo de um arquivo com caracteres estendidos, precisará especificar a codificação de arquivo.

Observação

Para ler um arquivo linha por linha de texto, use o método do objeto OpenTextFileReaderMy.Computer.FileSystem. O método OpenTextFileReader retorna um objeto StreamReader. Você pode usar o ReadLine método do StreamReader objeto para ler um arquivo uma linha de cada vez. Você pode testar o final do arquivo usando o EndOfStream método do StreamReader objeto.

Para ler de um arquivo de texto

Use o ReadAllText método do My.Computer.FileSystem objeto para ler o conteúdo de um arquivo de texto em uma cadeia de caracteres, fornecendo o caminho. O exemplo a seguir lê o conteúdo de test.txt em uma cadeia de caracteres e, em seguida, exibe-o em uma caixa de mensagem.

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

Para ler de um arquivo de texto codificado

Use o ReadAllText método do My.Computer.FileSystem objeto para ler o conteúdo de um arquivo de texto em uma cadeia de caracteres, fornecendo o caminho e o tipo de codificação de arquivo. O exemplo a seguir lê o conteúdo do arquivo UTF32 test.txt em uma cadeia de caracteres e o exibe em uma caixa de mensagem.

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

Para transferir dados de um arquivo de texto para um controle RichTextBox

Para carregar o conteúdo de um arquivo de texto diretamente em um controle RichTextBox, leia o conteúdo do arquivo em uma cadeia de caracteres e atribua-o Text à propriedade do RichTextBox. O exemplo a seguir mostra como ler um arquivo de texto e carregá-lo em um controle RichTextBox.

' Load text file into a RichTextBox control
' Note: This assumes RichTextBox1 is a control on your form
Dim fileText As String
fileText = My.Computer.FileSystem.ReadAllText("test.txt")
' RichTextBox1.Text = fileText

Para melhor tratamento de erros e gerenciamento de caminho de arquivo, você pode usar a abordagem a seguir que constrói um caminho de arquivo adequado e lida com possíveis exceções. Essa abordagem evita caminhos de unidade pré-definidos que podem causar problemas em diferentes sistemas.

' Load text file into a RichTextBox control using a specific path
Try
    Dim filePath As String = System.IO.Path.Combine(System.AppDomain.CurrentDomain.BaseDirectory, "test.txt")
    Dim fileText As String = My.Computer.FileSystem.ReadAllText(filePath)
    ' RichTextBox1.Text = fileText
Catch ex As System.IO.FileNotFoundException
    MsgBox("File not found: " & ex.Message)
Catch ex As Exception
    MsgBox("Error reading file: " & ex.Message)
End Try

Observação

Ao especificar caminhos de arquivo, evite usar caminhos absolutos codificados como "C:\temp\file.txt", pois eles podem causar problemas em sistemas em que a letra da unidade ou a estrutura do diretório é diferente. Em vez disso, use caminhos relativos ou caminhos de construção usando Combine para garantir que seu código funcione em ambientes diferentes.

Programação robusta

As seguintes condições podem causar uma exceção:

  • O caminho não é válido por um dos seguintes motivos: é uma cadeia de caracteres de comprimento zero, contém apenas espaço em branco, contém caracteres inválidos ou é um caminho do dispositivo (ArgumentException).

  • O caminho não é válido porque é Nothing (ArgumentNullException).

  • O arquivo não existe (FileNotFoundException).

  • O arquivo está em uso por outro processo ou ocorre um erro de E/S (IOException).

  • O caminho excede o comprimento máximo definido pelo sistema (PathTooLongException).

  • Um nome de arquivo ou diretório no caminho contém dois pontos (:) ou está em formato inválido (NotSupportedException).

  • Não há memória suficiente para gravar a cadeia de caracteres no buffer (OutOfMemoryException).

  • O usuário não tem permissões necessárias para exibir o caminho (SecurityException).

Não tome decisões sobre o conteúdo do arquivo com base no nome do arquivo. Por exemplo, o arquivo Form1.vb pode não ser um arquivo de origem do Visual Basic.

Verifique todas as entradas antes de usar os dados em seu aplicativo. O conteúdo do arquivo pode não ser o esperado e os métodos para ler do arquivo podem falhar.

Consulte também