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 : < /p> 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!