Excel四舍六入五单双公式

Question:
例如:修约为两位小数
0.3330→0.33 第三位小于5,第二位不加1
0.3340→0.33 第三位小于5,第二位不加1
0.3360→0.34 第三位小于5,第二位不加1
0.3350→0.34 第三位等于5,第四位为零,第二位是单数(奇数),第二位加1
0.3450→0.34 第三位等于5,第四位为零,第二位是双数(偶数),第二位不加1
0.3456→0.35 第三位等于5,第四位不为零,第二位加1

Answer:
=IF(MOD(INT(A1*1000),5)=0,IF(MOD(INT(A1*100),2)=0,INT(A1*100)/100,ROUND(A1,2)),ROUND(A1,2))

思路:首先,原数乘1000后取整数部分,用MOD判断其能否被5整除,将小数后第三位是5的另外列出来(当然是0的也被挑出来了)。
接着
(1)若不能,正常四舍五入即可。
(2)若能,则表示小数后第三位是0或5,这时我们判断原数乘100后取整能不能被2整除(这是判断小数点第二位是奇数还是偶数),若能,原数乘100后取整再除以100(这不就是取小数点后两位吗?),若不能,那么直接用ROUND函数。

引申:
修约为三位小数的公式
 =IF(MOD(INT(A1*10000),5)=0,IF(MOD(INT(A1*1000),2)=0,INT(A1*1000)/1000,ROUND(A1,3)),ROUND(A1,3))
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值