Como ler em arquivos de texto separados por vírgulas no Visual Basic
O objeto TextFieldParser
fornece uma maneira fácil e eficiente de analisar arquivos de texto estruturados, como logs. A propriedade TextFieldType
define se ele é um arquivo delimitado ou um arquivo com campos de texto de largura fixa.
Para analisar um arquivo de texto delimitado por vírgulas
Crie um
TextFieldParser
. O código a seguir cria oTextFieldParser
chamadoMyReader
e abre o arquivotest.txt
.Using MyReader As New Microsoft.VisualBasic. FileIO.TextFieldParser( "C:\TestFolder\test.txt")
Defina o delimitador e o tipo
TextField
. O código a seguir define a propriedadeTextFieldType
comoDelimited
e o delimitador como “,”.MyReader.TextFieldType = FileIO.FieldType.Delimited MyReader.SetDelimiters(",")
Percorra em loop os campos no arquivo. Se alguma linha estiver corrompida, relate um erro e continue a análise. O código a seguir faz um loop pelo arquivo, exibindo cada campo por sua vez e relatando quaisquer campos que estejam formatados incorretamente.
Dim currentRow As String() While Not MyReader.EndOfData Try currentRow = MyReader.ReadFields() Dim currentField As String For Each currentField In currentRow MsgBox(currentField) Next Catch ex As Microsoft.VisualBasic. FileIO.MalformedLineException MsgBox("Line " & ex.Message & "is not valid and will be skipped.") End Try
Feche os blocos
While
eUsing
comEnd While
eEnd Using
.End While End Using
Exemplo
Este exemplo lê do arquivo test.txt
.
Using MyReader As New Microsoft.VisualBasic.
FileIO.TextFieldParser(
"C:\TestFolder\test.txt")
MyReader.TextFieldType = FileIO.FieldType.Delimited
MyReader.SetDelimiters(",")
Dim currentRow As String()
While Not MyReader.EndOfData
Try
currentRow = MyReader.ReadFields()
Dim currentField As String
For Each currentField In currentRow
MsgBox(currentField)
Next
Catch ex As Microsoft.VisualBasic.
FileIO.MalformedLineException
MsgBox("Line " & ex.Message &
"is not valid and will be skipped.")
End Try
End While
End Using
Programação robusta
As seguintes condições podem causar uma exceção:
Não é possível analisar uma linha usando o formato especificado (MalformedLineException). A mensagem de exceção especifica a linha causando a exceção, enquanto a propriedade ErrorLine é atribuída ao texto contido na linha.
O arquivo especificado não existe (FileNotFoundException).
Uma situação de confiança parcial na qual o usuário não tem permissões suficientes para acessar o arquivo. (SecurityException).
O caminho é muito longo (PathTooLongException).
O usuário não tem permissões suficientes para acessar o arquivo (UnauthorizedAccessException).
Confira também
- Microsoft.VisualBasic.FileIO.TextFieldParser
- Como: ler de arquivos de texto de largura fixa
- Como: ler de arquivos de texto com vários formatos
- Analisando arquivos de texto com o objeto TextFieldParser
- Instruções passo a passo: manipulando arquivos e diretórios no Visual Basic
- Solução de problemas: ler e gravar em arquivos de texto