js数值四舍五入的方法以及其中潜在bug的解决方案

1.toFixed() 方法可把 Number 四舍五入为指定小数位数的数字。

NumberObject.toFixed(num)
num必需写,规定小数的位数,是 0 ~ 20 之间的值,包括 0 和 20,有些实现可以支持更大的数值范围。如果省略了该参数,将用 0 代替。

当num超过20的时候,js会出错,这东西好像只能传一个数字进去,字符串会爆不是一个方法

方法存在的bug:

Number(13.35).toFixed(1); //13.3 
Number(0.055).toFixed(1); //0.1
原因:原生toFixed(x)截取小数的时候会有误差
//如果要修改这个缺陷,可以把js中的number类型的tofixed方法重写。

2.Math.round() 方法可把一个数字舍入为最接近的整数。

Math.round(x)
x为需要计算的数值。该方法 返回与给出的数值表达式最接近的整数。

方法个存在的bug

Math.round(num * Math.pow(10, 2)) / Math.pow(10, 2);  //num是待处理数字Math.pow(10, 2)=100

当num = 10.10500时,计算上述表达式可得10.11。(正常)
当num = "10.50000"时(注意这里是字符串),计算上述表达式可得10.5。(damn it,小数点后位数不对!)
原因:当num是字符串,进行乘法操作时,进行了类型转换,后缀零被丢弃了,导致位数不足,这个时候我们就应该进行补0
 

解决方案:

var iTofixed =function(num,fractionDigits) {
return (Math.round(num*Math.pow(10,fractionDigits))/Math.pow(10,fractionDigits)+Math.pow(10,-(fractionDigits+1))).toString().slice(0, -1)
};
iTofixed('13.5000',3);
//"13.500"

在pandas中,可以使用round()函数对DataFrame中的数据进行四舍五入。在引用中的代码示例中,使用了round()函数对DataFrame中的数据进行了四舍五入的处理。 例如,如果有一个名为df的DataFrame,其中包含了一些数字数据,我们可以使用df.round()来对整个DataFrame中的数据进行四舍五入。可以通过传递一个参数来指定保留的小数位数。例如,df.round(2)表示将数据四舍五入到小数点后两位。 此外,还可以使用字典类型的参数来对特定的列进行不同的精度设置。例如,df.round({"col-1": 1, "col-2": 3})表示将"col-1"列的数据四舍五入到小数点后一位,将"col-2"列的数据四舍五入到小数点后三位。 在示例代码中,df_1和df_2分别是根据上述方式对DataFrame进行四舍五入的结果。 因此,根据引用中的代码示例,可以使用round()函数对pandas中的数据进行四舍五入处理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [pandas - DataFrame 数据格式化(四舍五入、百分比、千位分隔符,分割)(round、apply、map、split)](https://blog.csdn.net/weixin_42115865/article/details/131586025)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值