Como: ler a partir de arquivos de texto delimitados por vírgulas no Visual Basic
O TextFieldParser
objeto fornece uma maneira fácil e eficiente de analisar arquivos de texto estruturados, como logs. A TextFieldType
propriedade define se é um arquivo delimitado ou com campos de texto de largura fixa.
Para analisar um arquivo de texto delimitado por vírgulas
Crie um novo
TextFieldParser
arquivo . O código a seguir cria oTextFieldParser
nomeMyReader
e abre o arquivotest.txt
.Using MyReader As New Microsoft.VisualBasic. FileIO.TextFieldParser( "C:\TestFolder\test.txt")
Defina o tipo e o
TextField
delimitador. O código a seguir define aTextFieldType
propriedade comoDelimited
e o delimitador como ",".MyReader.TextFieldType = FileIO.FieldType.Delimited MyReader.SetDelimiters(",")
Percorra os campos no arquivo. Se alguma linha estiver corrompida, reporte um erro e continue analisando. O código a seguir percorre o arquivo, exibindo cada campo por sua vez e relatando quaisquer campos 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
While
blocos eUsing
comEnd While
eEnd Using
.End While End Using
Exemplo
Este exemplo lê o 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:
Uma linha não pode ser analisada usando o formato especificado (MalformedLineException). A mensagem de exceção especifica a linha que causa a exceção, enquanto a ErrorLine propriedade recebe o 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).
Consulte também
- Microsoft.VisualBasic.FileIO.TextFieldParser
- Como: Ler a partir de arquivos de texto de largura fixa
- Como: Ler a partir de arquivos de texto com vários formatos
- Analisando arquivos de texto com o objeto TextFieldParser
- Passo a passo: Manipulando arquivos e diretórios no Visual Basic
- Resolução de problemas: Ler e escrever em ficheiros de texto