Golang : Read large file with bufio.Scanner cause token too long error
There are couple of ways to read files with Golang and one of the common way to read in file is with bufio.NewScanner() function. For example :
package main
import (
"bufio"
"fmt"
"os"
)
func main() {
file, err := os.Open("somefile.dat")
if err != nil {
panic(err.Error())
}
defer file.Close()
reader := bufio.NewReader(file)
scanner := bufio.NewScanner(reader)
scanner.Split(bufio.ScanBytes)
for scanner.Scan() {
fmt.Println(scanner.Bytes())
}
if err := scanner.Err(); err != nil {
fmt.Println("error while reading :", err)
}
}
Most of the time, things should be fine and dandy. However, there will be cases when the program attempts to read in a very large file and it will throw out this error message :
"bufio.Scanner: token too long"
This error message was caused by the input token size that exceeded the bufio.MaxScanTokenSize
buffer size. The allocated size is MaxScanTokenSize = 64 * 1024
To read in large files, it is recommended to use bufio.Reader.ReadLine instead.
References :
See also : Golang : Scanf function weird error in Windows
By Adam Ng
IF you gain some knowledge or the information here solved your programming problem. Please consider donating to the less fortunate or some charities that you like. Apart from donation, planting trees, volunteering or reducing your carbon footprint will be great too.
Advertisement
Tutorials
+4.2k Adding Skype actions such as call and chat into web page examples
+14.6k JavaScript/JQuery : Detect or intercept enter key pressed example
+6.4k Default cipher that OpenSSL used to encrypt a PEM file
+7.5k Swift : Convert (cast) String to Double
+15.3k Golang : Convert date format and separator yyyy-mm-dd to dd-mm-yyyy
+22.3k Golang : simulate tail -f or read last line from log file example
+26.9k Golang : Convert integer to binary, octal, hexadecimal and back to integer
+7.7k Golang : Multiplexer with net/http and map
+19.3k Golang : Archive directory with tar and gzip
+35.9k Golang : Convert date or time stamp from string to time.Time type
+33.5k Golang : Proper way to set function argument default value