gpt4 book ai didi

vb.net - 高级文本搜索并将特定字符串从文件导入 VB

转载 作者:行者123 更新时间:2023-12-01 15:38:36 26 4
gpt4 key购买 nike

首先我要说这是我在 VBForums 上的第一篇帖子,我已经潜伏了一段时间。我是 VB 的新手,学习它只是为了完成我的论文。所以请原谅我的无知。

我正在尝试做的是从另一个程序生成的日志文件中读取数据。我需要将该文件中的特定行导入 VB 以用于其他算法。此日志文件将不断更新,因此需要尽可能实时读取。

如果重要的话,日志文件是从与另一软件通信的 USB 设备生成的。

这是一个示例日志:

`
08:57:00.932 COM12
08:57:00.935 COM11
08:57:00.935 COM10
08:57:00.936 COM9
08:57:00.936 COM8
08:57:00.937 COM7
08:57:00.938 COM6
08:57:00.939 COM5
08:57:00.939 COM4
08:57:00.998 --> 0108000304FF0000
08:57:01.007 <-- 0108000304FF0000

TRF7970A EVM


08:57:01.014 **** COM Port found! ****
08:57:05.009 --> 010A0003041001210000
08:57:05.009 COM4
08:57:05.173 <-- 010A0003041001210000

Register write request.


08:57:05.173 --> 010C00030410002101020000
08:57:05.280 <-- 010C00030410002101020000

Register write request.


08:57:05.280 --> 010B000304140601000000
08:57:05.715 <-- 010B000304140601000000

ISO 15693 Inventory request.

[,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40]D
08:57:05.716 --> 010A0003041001210000
08:57:05.822 <-- 010A0003041001210000

Register write request.


08:57:05.822 --> 010C00030410002101020000
08:57:05.929 <-- 010C00030410002101020000

Register write request.


08:57:05.929 --> 010B000304140601000000
08:57:06.364 <-- 010B000304140601000000

ISO 15693 Inventory request.

[,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40]D
08:57:06.365 --> 010A0003041001210000
08:57:06.470 <-- 010A0003041001210000

Register write request.


08:57:06.470 --> 010C00030410002101020000
08:57:06.576 <-- 010C00030410002101020000

Register write request.


08:57:06.576 --> 010B000304140601000000
08:57:07.011 <-- 010B000304140601000000

ISO 15693 Inventory request.

[,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40]D
08:57:07.012 --> 010A0003041001210000
08:57:07.117 <-- 010A0003041001210000

Register write request.


08:57:07.117 --> 010C00030410002101020000
08:57:07.223 <-- 010C00030410002101020000

Register write request.


08:57:07.223 --> 010B000304140601000000
08:57:07.658 <-- 010B000304140601000000

ISO 15693 Inventory request.

[,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40]D
08:57:07.659 --> 010A0003041001210000
08:57:07.764 <-- 010A0003041001210000

Register write request.


08:57:07.764 --> 010C00030410002101020000
08:57:07.870 <-- 010C00030410002101020000

Register write request.


08:57:07.870 --> 010B000304140601000000
08:57:08.305 <-- 010B000304140601000000

ISO 15693 Inventory request.

[,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40]D
08:57:08.306 --> 010A0003041001210000
08:57:08.411 <-- 010A0003041001210000

Register write request.


08:57:08.411 --> 010C00030410002101020000
08:57:08.517 <-- 010C00030410002101020000

Register write request.


08:57:08.517 --> 010B000304140601000000
08:57:08.952 <-- 010B000304140601000000

ISO 15693 Inventory request.

[,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40]D
08:57:08.952 --> 010A0003041001210000
08:57:09.058 <-- 010A0003041001210000

Register write request.


08:57:09.058 --> 010C00030410002101020000
08:57:09.164 <-- 010C00030410002101020000

Register write request.


08:57:09.164 --> 010B000304140601000000
08:57:09.585 <-- 010B000304140601000000

ISO 15693 Inventory request.

[,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40]

[AD87851A000007E0,7F]

[,40][,40]D
08:57:09.586 --> 010A0003041001210000
08:57:09.692 <-- 010A0003041001210000

Register write request.


08:57:09.692 --> 010C00030410002101020000
08:57:09.798 <-- 010C00030410002101020000

Register write request.


08:57:09.798 --> 010B000304140601000000
08:57:10.233 <-- 010B000304140601000000

ISO 15693 Inventory request.

[,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40][,40]D
08:57:10.234 --> 010A0003041001210000
08:57:10.340 <-- 010A0003041001210000

Register write request.


08:57:10.340 --> 010C00030410002101020000
08:57:10.446 <-- 010C00030410002101020000

Register write request.

`

我需要能够得到这条线:[AD87851A000007E0,7F]

只是“AD87851A000007E0”,然后能够在 VB 中使用该字符串。这是一个会变化的十六进制代码。

我已经能够从日志文件中读取,但没有产生有效的输出。

这是我一直在尝试使用的代码:

Function ReadData(ByRef keyword As String) As IEnumerable(Of String)
Dim result = New List(Of String)
Using reader = New StreamReader("C:\rfid-reader.log")
Dim line As String = reader.ReadLine()
Dim take = False
Do While line IsNot Nothing
If line.StartsWith("[") Then
take = False
End If
If String.Equals("[" + keyword + ",", line) Then
take = True
End If
If take And Not String.IsNullOrEmpty(line) And Not line.StartsWith("'") Then
result.Add(line)
End If
line = reader.ReadLine()
Label1.Text = line
Loop
End Using
Return result
End Function

老实说,我不确定代码是否无法正常工作,或者我只是在从函数中获取字符串方面做错了什么?该函数会按原样打印到 Label1.Text 吗?

我也试过这样调用函数:

Dim items = ReadData("AD87851A000007E0")

Label1.Text = Convert.ToString(items)

这导致 Label1.Text 变为“System.Collections.Generic.List`1[System.String]”


编辑 1

Imports System.IO

公开课Form1

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click

Dim items = ReadData("AD87851A000007E0")

Label1.Text = String.Join(Environment.NewLine, items)


End Sub

Function ReadData(ByRef keyword As String) As IEnumerable(Of String)
Dim result = New List(Of String)
Using reader = New StreamReader("C:\rfid-reader.log")
Dim line As String = reader.ReadLine()
Dim take = False
Do While line IsNot Nothing

take = False ' resetting take = false to avoide printing all lines

If line.StartsWith("[" + keyword + ",") Then
take = True
End If

If take And Not String.IsNullOrEmpty(line) And Not line.StartsWith("'") Then
result.Add(line)
End If
line = reader.ReadLine()
Loop
End Using
Return result
End Function

下课

编辑 2_______________________________________________

迄今为止的新代码:

Imports System.IO

公开课Form1

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click

Dim items = ReadData("AD87851A000007E0") ' Calling the specific hex code from the function. Advancement needed to get ALL hex codes.

' Dim items1 As String = Convert.ToString(items)
' Dim items2 As String = ""


' Dim k As Long
' k = InStrRev(items, ",")
' If k > 0 Then items2 = Left$(items, k)

Label1.Text = String.Join(Environment.NewLine, items) 'Printing function result to Label1


End Sub


'Function to search log file for a specific hex code. Removes not needed portions of the string. Advancements needed:
'Find ALL hex codes
'Ignore repeats until a reset is set true
'Store each hex code found in it's own variable for use in algorithms


Function ReadData(ByRef keyword As String) As IEnumerable(Of String)
Dim result = New List(Of String)
Using reader = New StreamReader("C:\rfid-reader.log")
Dim line As String = reader.ReadLine()
Dim take = False

Do While line IsNot Nothing
take = False ' resetting take = false to avoide printing all lines

If line.StartsWith("[" + keyword + ",") Then
take = True
End If


If take And Not String.IsNullOrEmpty(line) And Not line.StartsWith("'") Then
line = line.Remove(0, 1) 'removing the extra parts of the line
line = line.Remove(16, 4)
result.Add(line) 'adding the valid result

End If
line = reader.ReadLine()
Loop
End Using
Return result
End Function

下课


编辑 3

Imports System.IO

公开课Form1

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click

Dim items = ReadData("[") ' Calling the specific hex code from the function. Advancement needed to get ALL hex codes.

Label1.Text = String.Join(Environment.NewLine, items) 'Printing function result to Label1


End Sub


'Function to search log file for a specific hex code. Removes not needed portions of the string. Advancements needed:
'Find ALL hex codes
'Ignore repeats until a reset is set true
'Store each hex code found in it's own variable for use in algorithms


Function ReadData(ByRef keyword As String) As IEnumerable(Of String)
Dim result = New List(Of String)
Using reader = New StreamReader("C:\rfid-reader.log")
Dim line As String = reader.ReadLine()
Dim line1 As String = "COOKIES"
Dim line2 As String = "COOKIES1"
Dim line3 As String = "COOKIES2"
Dim line4 As String = "COOKIES3"
Dim line5 As String = "COOKIES4"
Dim line6 As String = "COOKIES5"
Dim line7 As String = "COOKIES6"
Dim line8 As String = "COOKIES7"
Dim line1found = False
Dim line2found = False
Dim line3found = False
Dim line4found = False
Dim line5found = False
Dim line6found = False
Dim line7found = False
Dim line8found = False
Dim take = False

Do While line IsNot Nothing

take = False ' resetting take = false to avoide printing all lines

If line.StartsWith(keyword) And Not line.StartsWith("[,4") And Not line.StartsWith("[z,") Then
take = True
End If

If line.Contains(line1) Or line.Contains(line2) Or line.Contains(line3) Or line.Contains(line4) Or line.Contains(line5) Or line.Contains(line6) Or line.Contains(line7) Or line.Contains(line8) Then 'attempting to ignore duplicates
take = False
End If

If take And Not String.IsNullOrEmpty(line) And Not line.StartsWith("'") Then
line = line.Remove(0, 1) 'removing the extra parts of the line
line = line.Remove(16, 4)
result.Add(line) 'adding the valid result

If line1 <> line And Not line1found Then 'assining results to variables for duplicate elimiation
line1 = line
line1found = True

ElseIf line2 <> line And line1 <> line And Not line2found Then
line2 = line
line2found = True

ElseIf line <> line3 And line <> line2 And line1 <> line And Not line3found Then
line3 = line
line3found = True

ElseIf line <> line4 And line <> line3 And line <> line2 And line <> line1 And Not line4found Then
line4 = line
line4found = True

ElseIf line <> line5 And line <> line4 And line <> line3 And line <> line2 And line <> line1 And Not line5found Then
line5 = line
line5found = True

ElseIf line6 <> line And line5 <> line And line4 <> line And line3 <> line And line2 <> line And line1 <> line And Not line6found Then
line6 = line
line6found = True

ElseIf line7 <> line And line6 <> line And line5 <> line And line4 <> line And line3 <> line And line2 <> line And line1 <> line And Not line7found Then
line7 = line
line7found = True

ElseIf line8 <> line And line7 <> line And line6 <> line And line5 <> line And line4 <> line And line3 <> line And line2 <> line And line1 <> line And Not line8found Then
line8 = line
line8found = True

End If
End If
line = reader.ReadLine()
Loop
End Using
Return result
End Function

下课

最佳答案

您的代码有几个问题。第一个问题是您使用的是 String.Equals 而不是 line.StartsWith:

If String.Equals("[" + keyword + ",", line) Then
take = True
End If

您会注意到,在上面的代码中,如果整行与字符串“[AD87851A000007E0,”完全匹配,它只会设置 take = True。但是您要查找的行不等于该字符串——它只是以该字符串开头。因此,您应该将该代码更改为:

If line.StartsWith("[" + keyword + ",") Then
take = True
End If

接下来,您将在循环读取每一行之后设置 Label1.Text = line,无论该行是否匹配。您正在做的事情会起作用,但可能不会以您想要的方式起作用。按照您现在的方式,它会用读取的每一行覆盖标签的整个文本内容。正如我所说,它对每一行都这样做,而不仅仅是匹配的行。由于您正忙于循环,在您完成之前屏幕不会真正刷新,所以最后,它所做的只是显示文件中的最后一行。

如果你想让它显示所有匹配的行,你需要把它移到 If take... block 中,你需要把这些行连接在一起,像这样:

If take And Not String.IsNullOrEmpty(line) And Not line.StartsWith("'") Then
result.Add(line)
Label1.Text = Label1.Text & Environment.NewLine & line
End If

但是,这仍然不是一个很好的方法。将 UI 代码与您的业务逻辑混合从来都不是一个好主意,因此您在调用 ReadData 之后设置标签的本能是正确的想法。但是,您不能使用 Convert.ToString 来显示列表的内容。正如您所发现的,这只会显示数据类型的名称。为此,您需要将列表中的字符串连接成一个字符串,如下所示:

Label1.Text = String.Join(Environment.NewLine, items)

我使用 Environment.NewLine 作为分隔符,但您可以使用任何您想要的分隔符。例如,如果你想在一行中显示它们,你可以使用 ", " 作为分隔符。

关于vb.net - 高级文本搜索并将特定字符串从文件导入 VB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15088359/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com