Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Tentukan bilangan bait baris CSV dalam Golang

Tentukan bilangan bait baris CSV dalam Golang

王林
王林ke hadapan
2024-02-05 23:33:081057semak imbas

确定 Golang 中 CSV 行有多少字节

Kandungan soalan

Saya mempunyai test.csv dan saya akan membacanya baris demi baris dan menentukan berapa banyak bait dalam setiap baris.

Ini sepatutnya lebih rendah daripada 37 bait kerana saya menggunakan Windows dan dua baris pertama mempunyai rn menambah sejumlah 4 bait.

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

Saya nak guna csv.NewReader() 简单地确定每行中有多少字节。但是,我知道在下面的代码中进行字节计数时,csv.Reader 不会计算每行中的逗号和 n .

Perlukah saya menambah beberapa matematik untuk bilangan koma dalam setiap baris + bilangan baris, rn -1 untuk menambah 2 bait bagi baris terakhir kerana ia tidak mempunyai rn? Ini terasa agak sukar, jadi saya lebih suka melihat jika ada penyelesaian yang lebih baik untuk masalah kiraan bait saya.

Kod saya:

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)

    }
}

Jawapan betul


Gunakan Reader.InputOffset untuk mendapatkan kedudukan semasa dalam fail: BD44F3686574B2610B9F6F11A1F9CFEF

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

Untuk mendapatkan bilangan bait setiap baris, tolak offset sebelumnya.

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

Atas ialah kandungan terperinci Tentukan bilangan bait baris CSV dalam Golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam