Golang : How to split or chunking a file to smaller pieces?
Problem :
You have a big file and you want to split / chunk the file into smaller pieces. How to do that in Golang?
Solution :
- Calculate the size of each chunk that you want to split the file into.
- Read the file content into a buffer(created according to the calculated chunk size).
- Write the buffer content into individual pieces.
Here you go :
package main
import (
"fmt"
"io/ioutil"
"math"
"os"
"strconv"
)
func main() {
fileToBeChunked := "./somebigfile"
file, err := os.Open(fileToBeChunked)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
defer file.Close()
fileInfo, _ := file.Stat()
var fileSize int64 = fileInfo.Size()
const fileChunk = 1 * (1 << 20) // 1 MB, change this to your requirement
// calculate total number of parts the file will be chunked into
totalPartsNum := uint64(math.Ceil(float64(fileSize) / float64(fileChunk)))
fmt.Printf("Splitting to %d pieces.\n", totalPartsNum)
for i := uint64(0); i < totalPartsNum; i++ {
partSize := int(math.Min(fileChunk, float64(fileSize-int64(i*fileChunk))))
partBuffer := make([]byte, partSize)
file.Read(partBuffer)
// write to disk
fileName := "somebigfile_" + strconv.FormatUint(i, 10)
_, err := os.Create(fileName)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
// write/save buffer to disk
ioutil.WriteFile(fileName, partBuffer, os.ModeAppend)
fmt.Println("Split to : ", fileName)
}
}
Sample output :
Splitting to 5 pieces.
Split to : somebigfile_1
Split to : somebigfile_2
Split to : somebigfile_3
Split to : somebigfile_4
References :
https://www.socketloop.com/tutorials/golang-convert-cast-int64-to-string
See also : Golang : Upload big file (larger than 100MB) to AWS S3 with multipart upload
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
+30.1k Golang : Math pow(the power of x^y) example
+12.6k Golang : Gin framework accept query string by post request example
+5.1k Golang : Dealing with backquote
+6.3k Golang : Dealing with postal or zip code example
+17.6k Golang : Populate dropdown with html/template example
+9.2k Golang : How to get quoted string into another string?
+19.9k Golang : GORM create record or insert new record into database example
+5.1k Golang : Extract XML attribute data with attr field tag example
+7.8k Golang : GMail API create and send draft with simple upload attachment example
+5k Golang : Experimenting with the Rejang script
+25.4k Golang : dial tcp: too many colons in address
+9.9k Android Studio : Create custom icons for your application example