Megosztás a következőn keresztül:


Útmutató: Olvasás több formátumot tartalmazó szövegfájlokból a Visual Basicben

Az TextFieldParser objektum segítségével könnyen és hatékonyan elemezheti a strukturált szövegfájlokat, például a naplókat. A több formátumot tartalmazó fájlokat a PeekChars metódus használatával feldolgozhatja az egyes sorok formátumának meghatározásához a fájl elemzése során.

Több formátumot tartalmazó szövegfájl elemzése

  1. Adjon hozzá egy testfile.txt nevű szövegfájlt a projekthez. Adja hozzá a következő tartalmat a szövegfájlhoz:

    Err  1001 Cannot access resource.
    Err  2014 Resource not found.
    Acc  10/03/2009User1      Administrator.
    Err  0323 Warning: Invalid access attempt.
    Acc  10/03/2009User2      Standard user.
    Acc  10/04/2009User2      Standard user.
    
  2. Adja meg a várt formátumot és a hiba jelentésekor használt formátumot. Az egyes tömbök utolsó bejegyzése -1, ezért az utolsó mező változószélességűnek számít. Ez akkor fordul elő, ha a tömb utolsó bejegyzése kisebb vagy egyenlő 0-nál.

    Dim stdFormat As Integer() = {5, 10, 11, -1}
    Dim errorFormat As Integer() = {5, 5, -1}
    
  3. Hozzon létre egy új TextFieldParser objektumot, amely meghatározza a szélességet és a formátumot.

    Using MyReader As New FileIO.TextFieldParser("..\..\testfile.txt")
        MyReader.TextFieldType = FileIO.FieldType.FixedWidth
        MyReader.FieldWidths = stdFormat
    
  4. Haladjon végig a sorokon, és tesztelje a formátumot, mielőtt olvasna.

    Dim currentRow As String()
    While Not MyReader.EndOfData
        Try
            Dim rowType = MyReader.PeekChars(3)
            If String.Compare(rowType, "Err") = 0 Then
                ' If this line describes an error, the format of the row will be different.
                MyReader.SetFieldWidths(errorFormat)
            Else
                ' Otherwise parse the fields normally
                MyReader.SetFieldWidths(stdFormat)
            End If
            currentRow = MyReader.ReadFields
            For Each newString In currentRow
                Console.Write(newString & "|")
            Next
            Console.WriteLine()
    
  5. Írja a hibákat a konzolra.

            Catch ex As Microsoft.VisualBasic.
                          FileIO.MalformedLineException
                MsgBox("Line " & ex.Message & " is invalid.")
            End Try
        End While
    End Using
    

példa

A fájlból testfile.txtbeolvasott teljes példa a következő:

Dim stdFormat As Integer() = {5, 10, 11, -1}
Dim errorFormat As Integer() = {5, 5, -1}
Using MyReader As New FileIO.TextFieldParser("..\..\testfile.txt")
    MyReader.TextFieldType = FileIO.FieldType.FixedWidth
    MyReader.FieldWidths = stdFormat
    Dim currentRow As String()
    While Not MyReader.EndOfData
        Try
            Dim rowType = MyReader.PeekChars(3)
            If String.Compare(rowType, "Err") = 0 Then
                ' If this line describes an error, the format of the row will be different.
                MyReader.SetFieldWidths(errorFormat)
            Else
                ' Otherwise parse the fields normally
                MyReader.SetFieldWidths(stdFormat)
            End If
            currentRow = MyReader.ReadFields
            For Each newString In currentRow
                Console.Write(newString & "|")
            Next
            Console.WriteLine()
        Catch ex As FileIO.MalformedLineException
            MsgBox("Line " & ex.Message & " is invalid.  Skipping")
        End Try
    End While
End Using
Console.ReadLine()

Robusztus programozás

A következő feltételek kivételt okozhatnak:

Lásd még