首頁 >後端開發 >Golang >決定 Golang 中 CSV 行有多少位元組

決定 Golang 中 CSV 行有多少位元組

王林
王林轉載
2024-02-05 23:33:081103瀏覽

确定 Golang 中 CSV 行有多少字节

問題內容

我有一個test.csv ,我將逐行讀取它並確定每行中有多少位元組.

這應該低於 37 個位元組,因為我在 Windows 上,前兩行有 \r\n 總共新增了 4 個位元組。

foo,bar,baz
100,200,300
400,500,600

我想使用 csv.NewReader() 簡單地確定每行中有多少位元組。但是,我知道在下面的程式碼中進行位元組計數時,csv.Reader 不會計算每行中的逗號和 \n

我是否應該為每行中的逗號數 行數添加一些數學運算,為 \r\n -1 為最後一行添加 2 個位元組,因為它沒有 \r\n?這感覺有點老套,所以我寧願看看是否有更好的解決方案來解決我的位元組計數問題。

我的程式碼:

package main

import (
    "encoding/csv"
    "fmt"
    "io"
    "log"
    "os"
)

func main() {
    file, err := os.Open("test.csv")
    if err != nil {
        log.Fatal(err)
    }
    defer file.Close()

    fileInfo, err := file.Stat()
    if err != nil {
        log.Fatal(err)
    }
    fmt.Printf("file total bytes is %d\n", fileInfo.Size())

    // init reader
    reader := csv.NewReader(file)

    // extract the header
    headers, err := reader.Read()
    if err != nil {
        log.Fatal(err)
    }
    fmt.Printf("headers are: %+v\n", headers)

    byteCounter := 0
    for {
        // if we reached end of file, stop
        if err == io.EOF {
            break
        }

        // read a record
        record, err := reader.Read()
        if err != nil {
            log.Fatal(err)
        }
        // loop through each record and count how many bytes
        for _, item := range record {
            byteCounter += len(item)
            fmt.Printf("record is %d bytes\n", len(item))
        }
        fmt.Println("total bytes so far is: ", byteCounter)

    }
}

正確答案


#使用 Reader.InputOffset 取得檔案中的目前位置: BD44F3686574B2610B9F6F11A1F9CFEF

https://www.php.cn/link/e2c2ff9c7fb57db574e461fbe467d84e

#要取得每行的位元組數,請減去先前的偏移量。

prevOffset := reader.InputOffset()

for {
    ...
    // read a record
    _, err := reader.Read()
    ...
    fmt.Println("line length is: ", reader.InputOffset()-prevOffset)
    prevOffset = reader.InputOffset()

}

https://www.php.cn/link/501e3f8a108d7ab9335ceecd363d113d

以上是決定 Golang 中 CSV 行有多少位元組的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:stackoverflow.com。如有侵權,請聯絡admin@php.cn刪除