down2323 2018-04-08 05:18
浏览 1303
已采纳

在使用dataframe.ReadCSV时指定分隔符

I'm trying to figure out how to use dataframe.LoadOptions in the gota library to specify a delimiter when reading the CSV file.

package main

import (
    "fmt"
    "github.com/kniren/gota/dataframe"
    "io/ioutil"
    "strings"
)

func main() {
    content, _ := ioutil.ReadFile("/path/to/csv/file.csv")
    ioContent := strings.NewReader(string(content))

    df := dataframe.ReadCSV(ioContent)

    fmt.Println(df)
}

The dataframe.ReadCSV function takes an options variable of type *dataframe.LoadOptions

I checked the definition for the dataframe.LoadOptions struct and found the following:

type LoadOption func(*loadOptions)

type loadOptions struct {
    defaultType series.Type
    detectTypes bool
    hasHeader bool
    names []string
    nanValues []string
    delimiter rune
    types map[string]series.Type
}

I'm new to Go and got stuck on this. First time I've come across a definition like this: type LoadOption func(*loadOptions)

  • 写回答

1条回答 默认 最新

  • dongtangxi1584 2018-04-08 10:33
    关注

    This library uses functional options.

    dataframe.ReadCSV takes any number of dataframe.LoadOption, where LoadOption is a function type. Look through the docs for things that return a value of LoadOption and pass those to ReadCSV:

    dataframe.ReadCSV(ioContent,
        dataframe.WithDelimiter(';'),
        dataframe.HasHeader(true),
        // etc.
    )
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签天线)
  • ¥15 机器人轨迹规划相关问题
  • ¥15 word样式右侧翻页键消失