Maison >développement back-end >Golang >Déterminer le nombre d'octets d'une ligne CSV dans Golang
J'ai un test.csv
et je vais le lire ligne par ligne et déterminer le nombre d'octets dans chaque ligne.
Cela devrait être inférieur à 37 octets car je suis sous Windows et les deux premières lignes ont rn
ajoutant un total de 4 octets.
foo,bar,baz 100,200,300 400,500,600
Je veux utiliser csv.NewReader()
简单地确定每行中有多少字节。但是,我知道在下面的代码中进行字节计数时,csv.Reader 不会计算每行中的逗号和 n
.
Dois-je ajouter quelques calculs pour le nombre de virgules dans chaque ligne + le nombre de lignes, rn
-1 pour ajouter 2 octets pour la dernière ligne puisqu'elle n'a pas de rn ? Cela semble un peu banal, donc je préfère voir s'il existe une meilleure solution à mon problème de nombre d'octets.
Mon code :
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) } }
Utilisez Reader.InputOffset pour obtenir la position actuelle dans le fichier : BD44F3686574B2610B9F6F11A1F9CFEF
https://www.php.cn/link/e2c2ff9c7fb57db574e461fbe467d84e
Pour obtenir le nombre d'octets par ligne, soustrayez le décalage précédent.
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
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!