在特定单词VB.NET之后解析文本文件

时间:2014-04-24 17:37:30

标签: vb.net parsing text .net

我有一个模块应用程序,它读取文本文件并查找包含特定单词的行。

我的输入看起来像这样

 Dealer Number: 90402001
 Dealer Name: SAN TAN FORD     
 Contract Number: 7466564   
 OverRide Class:       
 Contract Code: 3417620
 Portal Claim#: 148905

 Dealer Number: 90402001
 Dealer Name: SAN TAN FORD     
 Contract Number: 7679454   
 OverRide Class:       
 Contract Code: 3762406
 Portal Claim#: 149325

 Dealer Number: 90416003
 Dealer Name: CAR TOWN KIA     
 Contract Number: DG209507  
 OverRide Class:       
 Contract Code: 3110169
 Portal Claim#: 134550

 Dealer Number: 90430005
 Dealer Name: RICH FORD     
 Contract Number: 7380708   
 OverRide Class:       
 Contract Code: 3130744
 Portal Claim#: 148537

我的输出如下

 Dealer Name: SAN TAN FORD     Contract Number: 7466564
 Dealer Name: SAN TAN FORD     Contract Number: 7679454
 Dealer Name: RICH FORD        Contract Number: 7380708

现在我需要做的就是在" Number:"

之后抓取文字

这是我到目前为止所拥有的

 Imports System.IO

 Module Module1

Sub Main()

    Dim str
    Dim fileName = "C:\Users\username\Desktop\textfile.txt"

    Dim lines() = File.ReadAllLines(fileName)

    For i = 0 To lines.Length - 1
        If lines(i).Contains("SAN TAN FORD") Then
            Str = String.Format("{0}{1}", lines(i), lines(i + 1))
            Console.WriteLine(str)
        ElseIf lines(i).Contains("RICH FORD") Then
            Str = String.Format("{0}{1}", lines(i), lines(i + 1))
            Console.WriteLine(str)
        End If
    Next

End Sub

 End Module

我觉得有一些像line.after?所以它会像

 text = lines(i).after("Number:")
 Console.writeline(text)

这会给我

 7466564
 7679454
 7380708

想法?

2 个答案:

答案 0 :(得分:2)

有几种不同的方法可以做这样的事情。您可以使用IndexOfSubString来查找和提取所需字符串的部分。您可以使用Regex类来查找和读取匹配值,或者最简单的说,您可以使用Split方法。如果您认为字符串"Number: "是两个其他字符串之间的分隔符,那么您可以使用Split来获取该分隔符之前和之后的字符串。所以,例如:

Dim input As String = "Contract Number: 7380708"
Dim parts() As String = input.Split("Number: ")
Console.WriteLine(parts(0))  ' Outputs "Contract "
Console.WriteLine(parts(1))  ' Outputs "7380708"

答案 1 :(得分:0)

"之后没有""功能,但您可以使用split或indexof

执行类似的操作
    Dim input, output As String

    input = "Contract Number: 7466564"

    ' With trim
    output = input.Split(":")(1).Trim()
    Console.WriteLine(output)

    ' With index of
    output = input.Substring(input.IndexOf("Contract Number:") + "Contract Number:".Length).Trim()
    Console.WriteLine(output)