R.Net中的CreateDataFrame

时间:2016-06-23 10:38:49

标签: vb.net dataframe r.net

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

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)都是集合形式。

谢谢

1 个答案:

答案 0 :(得分: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数组。