go - 使用 Go 从 csv 数据框的列创建文本文件
问题描述
我正在尝试遍历csv
文件并输出标题为第一列中每一行的文本文件。然后用该列的其他行中的数据填充每个文本文件。我能够将内容打印csv
到文本文件中,但是我无法使用 for 循环来获取逻辑以获取第一列的索引并使用它来创建/命名一个新.txt
文件。
package main
import (
"fmt"
"io"
"io/ioutil"
"log"
"os"
)
func main() {
fmt.Println("Enter file path to CSV: ")
var csvFile string
_, err := fmt.Scanln(&csvFile)
if err != nil {
log.Fatal("Cannot read input")
return
}
//open file
inFile, err := os.Open(csvFile)
if err != nil {
log.Fatal(err)
}
defer inFile.Close()
readMe, _ := ioutil.ReadAll(inFile)
blankFile, err := os.Create(`C:\temp\test.txt`)
if err != nil {
log.Fatal(err)
}
defer blankFile.Close()
//write data to text file
outFile, err := blankFile.Write(readMe)
if err == io.EOF {
log.Fatalln("Failed")
} else if err != nil {
log.Fatal(err)
}
//print bytes total
fmt.Println(outFile, " bytes printed")
}
解决方案
从 csv 中获取多列并将每一列打印到一个新的文本文件中。
循环一个 csv 并生成一个新的文本文件,该文件将在第 1 行中的每一列之后命名。然后将使用该列的其他行中的数据填充每个文本文件。
例如,
package main
import (
"encoding/csv"
"fmt"
"io"
"os"
"path/filepath"
)
func CsvFileToTxtFiles(inFile string) error {
in, err := os.Open(inFile)
if err != nil {
return err
}
defer in.Close()
r := csv.NewReader(in)
hdr, err := r.Read()
if err != nil {
return err
}
f := make([]*os.File, len(hdr))
w := make([]*csv.Writer, len(hdr))
pfx := filepath.Clean(inFile)
pfx = pfx[:len(pfx)-len(filepath.Ext(pfx))]
for i, col := range hdr {
var err error
f[i], err = os.Create(pfx + "." + col + ".txt")
if err != nil {
return err
}
defer f[i].Close()
w[i] = csv.NewWriter(f[i])
if err != nil {
return err
}
defer w[i].Flush()
}
for {
row, err := r.Read()
if err != nil {
if row == nil && err == io.EOF {
break
}
return err
}
for i, col := range row {
err := w[i].Write([]string{col})
if err != nil {
return err
}
}
}
for i := range hdr {
var err error
w[i].Flush()
err = w[i].Error()
if err != nil {
return err
}
err = f[i].Close()
if err != nil {
return err
}
}
return nil
}
func main() {
if len(os.Args) <= 1 {
usage := "usage: " + filepath.Base(os.Args[0]) + " FILE"
fmt.Fprintln(os.Stderr, usage)
return
}
inFile := os.Args[1]
err := CsvFileToTxtFiles(inFile)
if err != nil {
fmt.Fprintln(os.Stderr, err)
return
}
}
输出:
$ cat ioj.test.csv
one,two,three
1,2,3
11,22,33
$ go run ioj.go ioj.test.csv
$ cat ioj.test.one.txt
1
11
$ cat ioj.test.two.txt
2
22
$ cat ioj.test.three.txt
3
33
$
推荐阅读
- powerquery - Power Query - 一列中有多种数据类型(日期和文本) - 添加条件列以分解数据
- python - 如何在 Python 中使用 ctypes 获得正确的结构大小
- javascript - 在我的 C: 驱动器上启动 EXE 的 Web 浏览器小书签
- c# - 在 C# 中读取字节数组并转换为浮点数
- java - IOException:无法运行程序“python”
- javascript - Ajax popup view update data using php with sql
- ubuntu - 如何在 Ubuntu 20.04 beta 上安装 php 5.6
- f# - Understanding F# value restriction
- c# - 如何在末尾使用空列值对 C# Datatable 进行排序
- android - charts_flutter - How to support non-zero Y-Axis values in bar chart with multiple stacks?