首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >R.Net中的CreateDataFrame

R.Net中的CreateDataFrame
EN

Stack Overflow用户
提问于 2016-06-23 18:38:49
回答 1查看 419关注 0票数 0

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

代码语言:javascript
复制
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[]’类型。

虽然我的列数据in columns和列名colList( data )是以集合的形式存在的。

谢谢

EN

回答 1

Stack Overflow用户

发布于 2017-05-26 20:07:36

也许你可以用

代码语言:javascript
复制
Dim columns() as IEnumerable 
Dim tableDF As DataFrame = engine.CreateDataFrame(columns.Cast(Of IEnumerable()), colList(data))

而不是

代码语言:javascript
复制
Dim columns as IEnumerable
Dim tableDF As DataFrame = engine.CreateDataFrame(columns, colList(data))

这里的问题是第一个参数是一个IEnumerables数组,您把它搞混了。然而,我不知道如何让data.Columns返回一个IEnumerables数组。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37989254

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档