Megjegyzés
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhat bejelentkezni vagy módosítani a címtárat.
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhatja módosítani a címtárat.
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
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.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}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 = stdFormatHaladjon 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()Í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:
- Egy sor nem elemezhető a megadott formátum (MalformedLineException) használatával. A kivételüzenet a kivételt okozó sort adja meg, míg a ErrorLine tulajdonság a sor szövegéhez van rendelve.
- A megadott fájl nem létezik (FileNotFoundException).
- Részleges megbízhatósági helyzet, amelyben a felhasználó nem rendelkezik megfelelő engedélyekkel a fájl eléréséhez. (SecurityException).
- Az elérési út túl hosszú (PathTooLongException).
- A felhasználó nem rendelkezik megfelelő engedélyekkel a fájl (UnauthorizedAccessException) eléréséhez.