0

我正在尝试使用 Rdotnet 在 vb.NET 上实现我的 R 脚本。首先,我从我的数据库中调用 SQL 存储过程来对数据进行一些预处理。这给了我一个 vb.NET 中的 DataTable 对象。然后,我打算使用 Rdotnet 运行我的 R 函数以进行进一步处理。由于我的 R 脚本只能读取数据框对象,因此我尝试使用 Rdotnet 中的 CreateDataFrame 函数创建数据框对象。请原谅我,但由于数据的敏感性,我无法提供实际数据。

Public Function Detect_Gridlock(ByVal data As DataTable)
    Dim engine As REngine = REngine.GetInstance()
    engine.Initialize()
    Dim columns As IEnumerable = data.Columns
    Dim tableDF As DataFrame = engine.CreateDataFrame(columns, colList(data))
    Return tableDF
End Function

Public Function colList(ByVal data As DataTable)
    Dim colNames(data.Columns.Count) As String
    Dim i As Integer = 1
    For Each column As DataColumn In data.Columns
        colNames(i) = column.ColumnName
    Next
    Return colNames

End Function

这给了我一条错误消息:无法将“System.Data.DataColumnCollection”类型的对象转换为“System.Collections.IEnumerable[]”类型。

虽然我的列中的列数据和列名 colList(data) 是集合的形式。

谢谢

4

1 回答 1

0

也许你可以使用

Dim columns() as IEnumerable 
Dim tableDF As DataFrame = engine.CreateDataFrame(columns.Cast(Of IEnumerable()), colList(data))

代替

Dim columns as IEnumerable
Dim tableDF As DataFrame = engine.CreateDataFrame(columns, colList(data))

这里的问题是第一个参数是 IEnumerables 的 ARRAY,您对此感到困惑。但是我不知道如何让 data.Columns 返回一个 IEnumerables 数组。

于 2017-05-26T12:07:35.887 回答