Golang : Round float to precision example
Just an add on for my previous tutorial on how to round up or down a float number. For this short tutorial, we will learn how to round float numbers to certain precision.
Instead of using
fmt.Printf("%0.2f \n", f)
fmt.Printf("%0.2f \n", Round(f)) // round half
fmt.Printf("%0.2f \n", RoundUp(f, 2)) // change 2 to 5 will have no effect
fmt.Printf("%0.2f \n", RoundDown(f, 3)) // change 3 to 4 will have no effect
which will output the precision up to 2 decimal point no matter how you instruct the Round, RoundUp and RoundDown functions.
This is because of fmt.Printf(%0.2\n)
will always overrule the final display format.
To fix this problem or to display the precision properly, you will have to use fmt.Println()
instead.
var f float64 = 123.123456
fmt.Printf("%0.2f \n", f)
fmt.Println(Round(f)) // round half
fmt.Println(RoundUp(f, 4)) // up to precision 4
fmt.Println(RoundDown(f, 4)) // up to precision 4
Output :
123.12
123
123.1235
123.1234
Here's the full code :
package main
import (
"fmt"
"math"
)
func Round(input float64) float64 {
if input < 0 {
return math.Ceil(input - 0.5)
}
return math.Floor(input + 0.5)
}
func RoundUp(input float64, places int) (newVal float64) {
var round float64
pow := math.Pow(10, float64(places))
digit := pow * input
round = math.Ceil(digit)
newVal = round / pow
return
}
func RoundDown(input float64, places int) (newVal float64) {
var round float64
pow := math.Pow(10, float64(places))
digit := pow * input
round = math.Floor(digit)
newVal = round / pow
return
}
func main() {
var f float64 = 123.123456
fmt.Printf("%0.2f \n", f)
fmt.Println(Round(f)) // round half
fmt.Println(RoundUp(f, 4))
fmt.Println(RoundDown(f, 4))
}
Reference :
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
+9.7k Golang : Generate random elements without repetition or duplicate
+7.1k Golang : Emulate NumPy way of creating matrix example
+8.4k Golang : Get all countries currencies code in JSON format
+12.4k Golang : Activate web camera and broadcast out base64 encoded images
+15.2k Golang : Send email and SMTP configuration example
+11.1k Golang : Forwarding a local port to a remote server example
+18.2k Golang : Compare floating-point numbers
+7.2k Your page has meta tags in the body instead of the head
+8.2k Golang : Web(Javascript) to server-side websocket example
+7.7k Golang : Accept any number of function arguments with three dots(...)
+3.9k Golang : A program that contain another program and executes it during run-time
+21.1k Golang : Read a file into an array or slice example