时间:2021-05-22
最近在项目中碰到很多次float转string,同时要求保留小数点后几位,并且去掉小数点后0的场景
虽然问题很简单,但是隔了挺久没处理这种场景就有些生疏了,自己也搜了一下,很多回答都不太满意。这里贴一下自己的做法,如果有更好的解决办法的话,还请多多指教
// 主要逻辑就是先乘,trunc之后再除回去,就达到了保留N位小数的效果func FormatFloat(num float64, decimal int) string { // 默认乘1 d := float64(1) if decimal > 0 { // 10的N次方 d = math.Pow10(decimal) } // math.trunc作用就是返回浮点数的整数部分 // 再除回去,小数点后无效的0也就不存在了 return strconv.FormatFloat(math.Trunc(num*d)/d, 'f', -1, 64)}其他的一些常用的格式化浮点数的demo
// 2代表精度,这种方式会有小数点后无效的0的情况 strconv.FormatFloat(123.123 'f', 2, 64) // 效果同上 fmt.Sprintf("%.2f", 123.123) // g可以去掉小数点后无效的0 fmt.Sprintf("%g", 123.00) // 效果同上,可以去掉0,但是达不到保留指定位数的效果 strconv.FormatFloat(a, 'g', -1, 64)上面这些例子其实灵活运用一下也可以达到最开始的效果
ps:下面看下golang 浮点数保留n位小数
程序员的天敌产品同学,就像UI妹子的甲方爸爸,总会提些你不想写的需求,还不能动手,比如某个数值经过 ÎÒ´òµÄ¾ÍÊÇÂÒÂë ,先保留3位小数,再经过%¥#@%&*%¥#%,再保留2位小数,在经过䅂䌱㈳ꃥꖽ�,取整。。。。。
故,有了下面的n位取整
func ChangeNumber(f float64, m int) string {n := strconv.FormatFloat(f, ‘f', -1, 32)if n == “” {return “”}if m >= len(n) {return n}。newn := strings.Split(n, “.”)if len(newn) < 2 || m >= len(newn[1]) {return n}return newn[0] + “.” + newn[1][:m]}为啥返回字符串类型??因为浮点数再进行各种各样的计算之后,很可能精度丢失,其中一个方法就是进行一次运算之后转化成字符串类型,然后由字符串类型转化成float类型,再进行接下来的运算,稳稳的✧(≖ ◡ ≖✿)
总结
到此这篇关于go浮点数转字符串保留小数点后N位的完美解决方法的文章就介绍到这了,更多相关go浮点数转字符串内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
控制浮点数打印格式浮点数的打印和格式控制是sprintf的一大常用功能,浮点数使用格式符”%f”控制,默认保留小数点后6位数字,比如:复制代码代码如下:spri
复制代码代码如下:floatDecimal.html//保留两位小数//功能:将浮点数四舍五入,取小数点后2位functiontoDecimal(x){varf
下面是一个示例:四舍五入保留小数点后两位复制代码代码如下:解释下%0.2f的含义:%表示起始字符0表示空位用0填满2表示小数点后必须占两位f表示转换成浮点数转换
本文实例讲述了JavaScript实现计算圆周率到小数点后100位的方法。分享给大家供大家参考,具体如下:浮点数的有效数位是16位,我自己做了一个大数类,能存储
对于一些小数点后有多位的浮点数,我们可能只需要保留2位,但js没有提供这样直接的函数,所以我们得自己写函数实现这个功能,代码如下:复制代码代码如下:functi