Golang小数操作指南之判断小数点位数与四舍五入

目录
  • 一、判断几位小数点
    • 1.判断几位小数点
  • 二、四舍五入
    • 1.fmt.Sprintf
    • 2.math.Round(result*pow)
  • 总结

一、判断几位小数点

1.判断几位小数点

加载 cast 包

go get github.com/spf13/cast

代码如下(示例):

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)
}

二、四舍五入

1.fmt.Sprintf

测试:

5.334
5.335
5.336

代码如下(示例):

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)
}

结果

从结果可以知道,官方包 fmt的四舍五入功能 不能达到我们的完美预期,四舍可以完成,但五入失败,只有当第三位成为六时才可生效

2.math.Round(result*pow)

测试:

5.334
5.335
5.336

代码如下(示例):

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
}

结果

从结果可以知道,math.Round(result*pow) 可以达到我们的完美预期,四舍五入可以完成。

总结

当官方包不足以满足我们的需要时,我们需要去寻找一个可以满足需要的方法来实现想要的功能,也将会在之后努力通过官方包实现四舍五入,让自己拓展知识面。

到此这篇关于Golang小数操作指南之判断小数点位数与四舍五入的文章就介绍到这了,更多相关Golang判断小数点与四舍五入内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • go浮点数转字符串保留小数点后N位的完美解决方法

    最近在项目中碰到很多次float转string,同时要求保留小数点后几位,并且去掉小数点后0的场景 虽然问题很简单,但是隔了挺久没处理这种场景就有些生疏了,自己也搜了一下,很多回答都不太满意.这里贴一下自己的做法,如果有更好的解决办法的话,还请多多指教 // 主要逻辑就是先乘,trunc之后再除回去,就达到了保留N位小数的效果 func FormatFloat(num float64, decimal int) string { // 默认乘1 d := float64(1) if decima

  • Golang小数操作指南之判断小数点位数与四舍五入

    目录 一.判断几位小数点 1.判断几位小数点 二.四舍五入 1.fmt.Sprintf 2.math.Round(result*pow) 总结 一.判断几位小数点 1.判断几位小数点 加载 cast 包 go get github.com/spf13/cast 代码如下(示例): package main import ( "fmt" "github.com/spf13/cast" "math" "regexp" "

  • jquery判断小数点两位和自动删除小数两位后的数字

    jquery判断小数点两位和自动删除小数两位后的数字 基本就是,输入12.235689741 会转换成12.23,不会四舍五入啦 会javascript基础的都应该能看明白啦 不解释 复制代码 代码如下: $("#fileds").find("input").blur(function(){ var value=$(this).val(); if(value == null || value == ''){ return false; } if(!isNaN(val

  • java判断三位数的实例讲解

    java怎么判断三位数 先定义个测试数字,如图 然后可以把数字转换成字符串来判断它的长度是否为3,如图 获取判断数字范围是否在100到1000之间的值,如图 在或者判断数字大于100且除以100或是小于10的数,如图 使用循环处理2次10或还有值,这时在判断这个值除以10后是不是等于0 ,如图 如果是小数值需要判断可以把数字转成字符串然后在替换掉小数点来判断长度也可以,如图

  • Python 如何强制限定小数点位数

    利用''%.af''%b--其中 b 代表要限定的数字, a 代表要求限定小数点的位数,结果自动四舍五入. 例: c = 1.264871331241212 print("%.3f"%c) 运行结果: 1.265 补充:Python Numpy数组格式化打印 (指定小数点位数) Numpy数组格式化打印方法 (指定小数点位数)np.set_printoptions(precision=3, suppress=True) precision:保留几位小数,后面不会补0 supress:对

  • golang针对map的判断,删除操作示例

    本文实例讲述了golang针对map的判断,删除操作.分享给大家供大家参考,具体如下: map是一种key-value的关系,一般都会使用make来初始化内存,有助于减少后续新增操作的内存分配次数.假如一开始定义了话,但没有用make来初始化,会报错的. 复制代码 代码如下: package main import ( "fmt" ) func main(){ var test =  map[string]string{"姓名":"李四",&qu

  • c#判断操作系统位数的示例分享

    在.net 4.5中,判断操作系统不用再写方法去判断了,有直接可以利用的属性了哦,如下所示:Environment.Is64BitProcess 属性.NET Framework 4.5 确定当前进程是否为 64 位进程. 当然如果是用的.net 4.5以前的童鞋也不必担心,同样也可以用以下的方法来实现判断系统位数. 复制代码 代码如下: private string Distinguish64or32System(){try{string addressWidth = String.Empty

  • python中实现控制小数点位数的方法

    前段时间遇到一个问题,python中怎么设置小数点位数,经过查资料,在这里整理了两种较为简单的方法: 法1:利用python内置的round()函数 a = 1.1314 a = 1.0000 a = 1.1267 b = round(a, 2) b = round(a, 2) b = round(a, 2) output: b=1.13 output: b=1.0 output: b=1.13 法2: a = 1.1314 a = 1.0000 a = 1.1267 b = '%.2f' %

  • .net decimal保留指定的小数位数(不四舍五入)

    前言 项目中遇到分摊金额的情况,最后一条的金额=总金额-已经分摊金额的和. 这样可能导致最后一条分摊的时候是负数,所以自己写了一个保留指定位数小数的方法. 扩展方法的使用,使得调用起来很优雅. 示例代码 public static class DecimalExtension { /// <summary> /// decimal保留指定位数小数 /// </summary> /// <param name="num">原始数量</param&

  • Python 格式化输出_String Formatting_控制小数点位数的实例详解

    问题概述: 有时候在使用print函数输出时,往往需要不断地切换字符串和变量,操作起来很不方便,需要不断地打引号和逗号.比如: firstName = 'Bob' lastName = 'Dylan' print('你的名字是 ', firstName, '你的姓是', lastName) 好在我们可以用%来代替变量名,最后再依次序解释每个%对应的变量是什么就可以了. firstName = 'Bob' lastName = 'Dylan' print('你的名字是%s, 你的姓是%s' % (

  • R语言 小数点位数的设置方式

    经常用数据分析,有时不同的文件的小数位数不一样,但是我们可以让它们的位数保持一致的,下面的介绍就是设置小数位数. 使用options函数 > options(digits) 默认为7位 > a=0.234333323#9位> a[1] 0.2343333 下面开始设置下 > options(digits=3)> a=0.34434434#8位> a[1] 0.344 看最大的位数 > options(digits=27)Error in options(digit

随机推荐