Juzgar puntos decimales y redondeo de operaciones decimales en Golang

Juzgar puntos decimales y redondeo de operaciones decimales en Golang

Golang fácil de aprender


Primero, determine cuántos puntos decimales

1. Determina cuántos puntos decimales

Cargue el paquete de yeso

ve a github.com/spf13/cast

El código es el siguiente (ejemplo):

package main

import (
	"fmt"
	"github.com/spf13/cast"
	"math"
	"regexp"
	"strconv"
)

func main() {
    
    

	num1 := 5.335

	// 判断几位小数
	decimal, _ := CheckDecimal(cast.ToString(num1), "2")

	fmt.Println(decimal)

}

// CheckDecimal 判断小数点后几位小数点
// str 所要判断的 小数字符串
// n 所要判断的 位数
func CheckDecimal(str string, n string) (bool, error) {
    
    

	// 通过 regexp 的 正则比较
	// ([1-9]\d*) 1-9 的任意位数
	// (0) 或者第一位是 0
	// d{0,`+n+`} 0-n 位数
	return regexp.MatchString(`^(([1-9]\d*)|(0))(\.\d{0,`+n+`})?$`, str)
}


2. Redondeo

1.fmt.Sprintf

prueba:

5.334
5.335
5.336

El código es el siguiente (ejemplo):

package main

import (
	"fmt"
	"github.com/spf13/cast"
	"math"
	"strconv"
)

func main() {
    
    

	num1 := 5.334

	fmt.Println(Float64Rand(num1,2))

}

//四舍五入
func Float64Rand(v float64, dig int) float64 {
    
    
	cDig := strconv.Itoa(dig)
	val := fmt.Sprintf("%0."+cDig+"f", v)
	return cast.ToFloat64(val)
}

resultado

inserte la descripción de la imagen aquí
A partir de los resultados, podemos saber que la función de redondeo del paquete oficial fmt no puede cumplir con nuestras expectativas perfectas.

2.math.Round(resultado*pow)

prueba:

5.334
5.335
5.336

El código es el siguiente (ejemplo):

package main

import (
	"fmt"
	"github.com/spf13/cast"
	"math"
	"strconv"
)

func main() {
    
    

	num1 := 5.334
	fmt.Println("num1:",num1)
	fmt.Println("res1:",FormatFloat(num1,2))

	num2 := 5.335
	fmt.Println("num2:",num2)
	fmt.Println("res2:",FormatFloat(num2,2))

	num3 := 5.336
	fmt.Println("num3:",num3)
	fmt.Println("res3:",FormatFloat(num3,2))

}

func FormatFloat(f float64, dig int) float64 {
    
    
	result := cast.ToFloat64(strconv.FormatFloat(f, 'f', dig+1, 64))

	pow := math.Pow(10, float64(dig))

	return math.Round(result*pow) / pow
}

resultado

inserte la descripción de la imagen aquí
Como puede ver en los resultados, math.Round(result*pow) puede lograr nuestra expectativa perfecta y se puede realizar el redondeo.


Resumir

Cuando el paquete oficial no es suficiente para satisfacer nuestras necesidades, necesitamos encontrar un método que pueda satisfacer nuestras necesidades para lograr la función deseada, y nos esforzaremos por lograr el redondeo a través del paquete oficial en el futuro, para que podamos expandir nuestro conocimiento.

Espero que este blog te sea útil. Soy el Rey de la Luz y hablo por mí mismo.

Supongo que te gusta

Origin blog.csdn.net/moer0/article/details/123192927
Recomendado
Clasificación