gpt4 book ai didi

r - FSharp R.data_frame

转载 作者:行者123 更新时间:2023-12-05 00:27:53 25 4
gpt4 key购买 nike

我正在通过 .csv 类型提供程序从 .csv 中获取一些数据,并将其放入 R 使用的数据框中。

这是导入:

#r @"..\packages\R.NET.1.5.5\lib\net40\RDotNet.dll"
#r @"..\packages\RDotNet.FSharp.0.1.2.1\lib\net40\RDotNet.FSharp.dll"
#r @"..\packages\RProvider.1.0.3\lib\RProvider.dll"
#r @"..\packages\FSharp.Data.1.1.10\lib\net40\FSharp.Data.dll"

open System
open RDotNet
open RProvider
open RProvider.``base``
open RProvider.graphics
open FSharp.Data.Csv
open System.IO

let data = CsvFile.Load(@"C:\TEST.csv")
let date = data.Data |> Seq.map(fun r -> r.Columns.[3])
let time = data.Data |> Seq.map(fun r -> r.Columns.[10])
let disposition = data.Data |> Seq.map(fun r -> r.Columns.[11]);

let month = data.Data |> Seq.map(fun r -> r.Columns.[4])
let time2 = data.Data |> Seq.map(fun r -> r.Columns.[7])

当我尝试创建数据框时,出现以下异常 - 无论我尝试加载的数据类型如何:

System.Exception:没有为 Microsoft.FSharp.Collections.FSharpList 类型注册的转换器 1[[System.Tuple 2[[System.String, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089],[System.Collections.Generic.IEnumerable`1[[System.String, mscorlib, Version=4.0.0.0, Culture=中性,PublicKeyToken=b77a5c561934e089]],mscorlib,版本=4.0.0.0,Culture=neutral,PublicKeyToken=b77a5c561934e089]],mscorlib,版本=4.0.0.0,Culture=neutral,PublicKey54e089a]5087

这是 DF 负载的示例。
let namedParameters = [
"month",month;
"time",time2;]


namedParameters
|> R.data_frame
|> R.plot

问题是 - 有 int 数据类型。它是捡起标题吗?我需要投吗?如果是这样,这不是类型提供程序的用途吗?我错过了什么?提前致谢。

最佳答案

R.data_frame您需要的重载是使用键值对字典的重载。您可以自己构建此字典,也可以使用 namedParams R 类型提供程序库中包含的函数。

为避免混淆,我将您的配对列表重命名为 df .然后你可以创建一个这样的框架:

let df = 
[ "month", month
"time", time2 ]

namedParams df
|> R.data_frame
|> R.plot

PS:你有什么理由使用 CsvFile动态读取数据,而不是使用 CSV type provider哪个应该(假设它适用于您的输入)为您提供对 CSV 数据的更好的键入数据访问?

关于r - FSharp R.data_frame,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19713216/

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