设置变量字符串以从结构化数组中获取值



我在 VB.net 有一个简单的问题。 我想使用字符串从声明为结构的数组中检索数据以可视化变量。 在我的代码下面:

Module DataAnalisys
Dim InputData(100000) As InputDataStructure
Dim VariablesParameter(6) As VariablesParameterStructure
Dim VariablesGlobal(6) As VariablesDataStrucutre
Structure InputDataStructure
Dim ID As Integer
Dim FileId As Integer
Dim ProductionDate As Date
Dim ProductionTime As Date
Dim Shift As Integer
Dim IPP As Integer
Dim BPS As Integer
Dim SerialNumber As String
Dim Top As Single
Dim Bottom As Single
Dim Right As Single
Dim Left As Single
Dim OffCutH As Single
Dim OffCutV As Single
Dim Row As Byte
Dim Col As String
Dim Position As String
Dim Pack As Integer
Dim Sheet As Integer
Dim SheetInPack As Integer
End Structure
Structure VariablesParameterStructure
Dim NameParameter As String
Dim Target As Single
Dim Tolerance As Single
Dim LowTolerance As Single
Dim UppTolerance As Single
End Structure
Structure VariablesDataStrucutre
Dim NameData As String
Dim Position As String
Dim N As Long
Dim Mean As Single
Dim Difference As Single
Dim Scrap As Single
Dim ScrapGreat As Single
Dim ScrapLess As Single
Dim SeMean As Single
Dim StDev As Single
Dim Min As Single
Dim Q1 As Single
Dim Median As Single
Dim Q3 As Single
Dim Max As Single
End Structure
Sub RoutineAnalisysGlobal()
For B As Byte = 0 To VariablesGlobal.Length - 1
Dim ID As String = VariablesParameter(B).NameParameter
Dim Target As Single = VariablesParameter(B).Target
Dim LowTol As Single = VariablesParameter(B).LowTolerance
Dim UppTol As Single = VariablesParameter(B).UppTolerance
With VariablesGlobal(B)
.NameData = ID
.Position = "All"
.N = InputData.Length
.Mean = InputData.Average(Function(f) f.ID)
.Difference = .Mean - Target
.ScrapLess = InputData.Count(Function(f) f.ID < LowTol)
.ScrapGreat = InputData.Count(Function(f) f.ID > UppTol)
.Q1 = InputData.FirstQuartile(Function(F) F.ID)
.Min = InputData.Min(Function(f) f.ID)
.Median = InputdataMedian(Function(f) f.ID)
.Q3 = InputData.ThirdQuartile(Function(f) f.ID)
.Max = InputData.Max(Function(f) f.ID)
End With
Next
End Sub
End Module

变量参数()。名称为Top,Bottom,Right,Left,OffCutH和OffCutV。

当我使用部分(函数(f) f.ID)时,代码不起作用,因为我想根据 for 循环在 InputData 结构的不同项目上使用该函数。我想显示 f.Top f.Bottom f.Right f.Left f.OffCutH 和 f.OffCutV。

有人想帮助我吗?我正在寻找如何将字符串ID转换为InputData的变量??????结构。

我认为您要查找的是这样的:

Dim functions As Func(Of InputDataStructure, Single)() = {Function(ids) ids.Top,
Function(ids) ids.Bottom,
Function(ids) ids.Right,
Function(ids) ids.Left,
Function(ids) ids.OffCutH,
Function(ids) ids.OffCutV}
For i = 0 To VariablesGlobal.GetUpperBound(0)
With VariablesGlobal(i)
'...
.Mean = InputData.Average(functions(i))
'...
End With
Next

作为解释,这一行的Function(f) f.ID部分:

.Mean = InputData.Average(Function(f) f.ID)

是一个 lambda 表达式,即匿名方法的委托。您正在调用的Average方法需要一个委托,该方法具有T类型的单个参数,其中T与要调用它的IEnumerable(Of T)的泛型类型匹配,并返回数值类型的值,例如IntegerSingle.在您的情况下,您正在InputData上调用Average,这实现了IEnumerable(Of InputDataStructure)。您的 lambda 表达式具有InputDataStructure类型的参数并返回一个Integer,因此它适用于AverageAverage方法为列表中的每个项目调用该委托,获取所有数值结果,然后将其除以列表中的项目数以获得平均值。

为了更清楚地了解那里发生了什么,您可以使用命名方法而不是 lambda 表达式。你可以编写这个方法:

Private Function GetID(f As InputDataStructure) As Integer
Return f.ID
End Function

然后将您的代码更改为以下内容:

.Mean = InputData.Average(AddressOf GetID)

希望您可以识别该命名方法中与 lambda 表达式对应的部分以及推断的部分。

现在,您有许多代码行使用相同的 lambda 表达式,例如

.Min = InputData.Min(Function(f) f.ID)
.Median = InputdataMedian(Function(f) f.ID)
.Q3 = InputData.ThirdQuartile(Function(f) f.ID)

对于如此简单的事情,习惯上按照自己的方式去做。但是,您可以选择编写一次 lambda 表达式,将其分配给变量,然后多次使用该变量。你可以这样做:

Dim f As Func(Of InputDataStructure, Integer) = Function(ids) ids.ID

或者这个:

Dim f = Function(ids As InputDataStructure) ids.ID

以变量结束f引用一个委托,该委托接受类型InputDataStructure的参数并返回类型Integer的值。然后,您可以在之前使用多个 lambda 表达式的位置使用该变量:

.Min = InputData.Min(f)
.Median = InputdataMedian(f)
.Q3 = InputData.ThirdQuartile(f)

因此,既然我们确定您所需要的只是一个接受正确类型的参数并返回正确类型的方法的委托,请再看看我发布的代码。它首先创建一个由六个委托组成的数组,每个委托接受一个类型InputDataStructure的参数并返回一个类型为Single的值。然后,您可以在需要此类委托的任何位置使用该数组的元素。

这意味着您可以遍历该数组并将每个委托传递给需要此类委托的所有扩展方法,包括Average。如果获取索引为 0 处的委托,则获取返回Top属性值的委托,因此Average将获取平均值Top值。如果使用索引 5,则会获取返回OffCutV属性值的委托,因此Average将获取平均值OffCutV值。等。

作为记录,我建议在 lambda 中使用指示类型的参数名称。你用过f但这毫无意义。参数类型InputDataStructure因此ids表示这一点。

最新更新