百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

7种常见“小数处理”模型

csdh11 2025-03-04 11:40 14 浏览

在交易范畴和支付范畴里面,我们常常会发现小数除不尽的情况。本文总结了7种常见“小数处理”模型,供大家在实际场景中选择合适的模型。

在交易范畴和支付范畴经常出现小数除不尽,或者乘数结果小数位数太多的情况,需要对小数进行处理因为,数据库存储小数,往往会设定位数或者最小单位,例如保留两位小数,或者金额的最小单位为分,数值只能为整数。

常见的业务有以下这些:

  • 交易范畴的优惠分摊金额的小数处理
  • 支付范畴的多次分账每次分账金额的小数处理
  • 收款手续费处理
  • 多次退款的手续费处理
  • 利息的处理

一、除不尽的场景

分摊时,如一笔订单优惠10元,分摊到3个商品上,那么每个商品分摊多少,很明显10?3=3.333…是除不尽的,这时候最终每个商品分摊了多少优惠?分账时,如一笔收款100块,现在要平均分账7笔,每笔应该分多少钱,这里100?7=14.2857143…,那么如何执行分账?

二、相乘位数增加的场景

计算手续费时,例如手续费率0.38%,一笔收款568元,此时应收手续费568*0.38%=2.158假如需要保留两位小数,那么最终手续费收多少呢?这里的规则需要跟商户预先约定方法不重要,重要的是共识,没有合不合理,只有愿不愿意。

大原则肯定是“公平”,何为公平就是“不多付一分钱,不少收一分钱,刚刚好”,而出现小数要处理也是迫不得已,那么也要尽可能保证公平,如果实在是做不到绝对公平,那么就做到各方共识,都能接受。

下面总结了7种常见的小数处理方法,以及适用的场景,全部以保留2位小数为前提。

1. 去尾法

保留位数后的值直接舍去,这个方法会让数偏小可以用在“不能高于”的限制场景,比如多次分账,不能超过总分账金额,那么前面的分账都可以直接去尾,最后进行调整示例:

568*0.38%=2.159,去尾以后为2.15像银行给客户的利息可以考虑去尾法,这样整体来说,可以降低银行的资金成本另外我们日常买东西也经常用去尾法,比如买菜,一共2.53,你可能会说“老板,零头别要了”,直接2.5就可以了。

2. 进一法

只要保留位数以后有数值,则直接进一,数会偏大可以在“不低于的“限制场景使用,比如你去给领导买可乐,一共8个领导,每人一瓶;假如一箱共6瓶可乐,那么8?6=1.3333…,只能买2箱(不零卖)示例:568*0.38%=2.151,有数则进1,处理后结果为2.16

3. 四舍五入

这是最常见的处理方法,整体数值会偏大,小于5时舍去,大于等于5时进一像微信的交易收款手续费采用的就是“四舍五入法”示例:568*0.38%=2.158,8大于5直接进1,为2.16

4. 四舍六入五成双

该方法比“四舍五入”更精确,当数据量大时结果更接近真实数值因为1、2、3、4、5、6、7、8、9中,5正好在中间位置,如果四舍五入,很明显进一的场景要比舍去的场景多“1”那么为了更公平就以5为分界线,小于5舍去,大于5进1,而当等于5时分情况处理如果5后还有数则进1,例如2.12500009,因为5后还有数,那么就进1,结果为2.13如果5后没有数了,要看5前面的数是奇数还是偶数,奇数时舍5进1,偶数时舍5不进(0为偶数),例如:2.175,5前面的“7”是奇数,则舍5进1,结果为2.182.165,5前面的“6”是偶数,则舍5不进,结果为2.16

5. 余数分配,补差法

当除不尽时,对余数设定分配策略,先处理除尽的部分,最后补全差额,这样的方法会让个别有误差,但整体没有误差例如开头的分摊例子:

一笔订单优惠10元,分摊到3个商品上,那么每个商品分摊多少,很明显10?3除不尽,整数结果是3,余数是1,那么2个商品分摊3,另一个分摊4如果保留2位小数,则10?3=3.333333…,其中2个商品分摊3.33,最后一个商品分摊10-3.33-3.33=3.34该方法可以用于优惠分摊和分账,包括退款手续费的处理,微信的退款手续费规则中有该方法余数分配方法可以与其他方法联合使用,以确保最终的公平性例如微信多次退款时的手续费处理,前面按照“向下取整”的策略,而最后一次退款退回全部手续费,实际上就是对余数进行补齐的策略,虽然前面手续费少退了,但是最后全给你补上了

6. 向上取整

有数值则进1,这样会让数值偏大,但在最后一次进行调整,保证整体无误差,如微信支付在规则调整前部分退款的手续费是“向上取整”,这样就意味着多次退款时,前面返给商家的手续费偏高示例:2.12100009,向上取整则结果为2.13,看起来和进一法效果类似

7. 向下取整

与向上取整向反,直接舍去,跟去尾法相似目前微信支付多次退款的手续费退回处理策略是“向下取整”微信支付采用了多种小数处理策略,交易手续费采用“四舍五入”,多次退款时采用“向下取整+余数补齐”例如开头的交易示例:手续费率0.38%,一笔收款568元,此时应收手续费568*0.38%=2.158,“四舍五入”以后为2.16如果全额退款直接退2.16即可如果是部分时,退款手续费计算规则是:

退款手续费=退款金额/总金额*交易手续费

  • 假如第一次退款268元,则268/568*2.16=1.019=1.01(向下取整)
  • 第二次退款169元,则169/568*2.16=0.642=0.64(向下取整)
  • 第三次退131元,即退剩下的全部,则应退手续费2.16-1.01-0.64=0.51(余数分配,调整差额)

最后,实际工作中可以根据实际业务情况灵活选择和组合,或者设计出更优的模型出来,例如“平常向下取整,年终一次性补齐整体差额”等,以确保尽可能的公平和大家都能接受的模型执行。

专栏作家

陈天宇宙,微信公众号:陈天宇宙,人人都是产品经理专栏作家。多平台支付领域专栏作者,十年资深产品;专注为10万支付产品经理和支付机构以及企业提供深度支付内容和服务!

本文原创发布于人人都是产品经理,未经许可,禁止转载。

题图来自 Unsplash,基于 CC0 协议。

该文观点仅代表作者本人,人人都是产品经理平台仅提供信息存储空间服务。

相关推荐

pdf怎么在线阅读?这几种在线阅读方法看看

pdf怎么在线阅读?我们日常生活中经常使用到pdf文档。这种格式的文档在不同平台和设备上的可移植性,以及保留文档格式和布局的能力都很强。在阅读这种文档的时候,很多人会选择使用在线阅读的方法。在线阅读P...

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异在日常工作和学习中,PDF文件可谓是无处不在。然而,有时我们需要比较两个PDF文件之间的差异,这可不是一件轻松的事情。手动逐页对比简直是...

全网爆火!580页Python编程快速上手,零基础也能轻松学会

Python虽然一向号称新手友好,但对完全零基础的编程小白来讲,总会在很长时间内,都对某些概念似懂非懂,每次拿起书本教程,都要从第一章看起。对于这种迟迟入不了门的情况,给大家推荐一份简单易懂的入门级教...

我的名片能运行Linux和Python,还能玩2048小游戏,成本只要20元

晓查发自凹非寺量子位报道|公众号QbitAI猜猜它是什么?印着姓名、职位和邮箱,看起来是个名片。可是右下角有芯片,看起来又像是个PCB电路板。其实它是一台超迷你的ARM计算机,不仅能够运...

由浅入深学shell,70页shell脚本编程入门,满满干货建议收藏

不会Linux的程序员不是好程序员,不会shell编程就不能说自己会Linux。shell作为Unix第一个脚本语言,结合了延展性和高效的优点,保持独有的编程特色,并不断地优化,使得它能与其他脚本语言...

真工程师:20块钱做了张「名片」,可以跑Linux和Python

机器之心报道参与:思源、杜伟、泽南对于一个工程师来说,如何在一张名片上宣告自己的实力?在上面制造一台完整的计算机说不定是个好主意。最近,美国一名嵌入式系统工程师GeorgeHilliard的名片...

《Linux 命令行大全》.pdf

今天跟大家推荐个Linux命令行教程:《TheLinuxCommandLine》,中文译名:《Linux命令行大全》。该书作者出自自美国一名开发者,兼知名Linux博客LinuxCo...

PDF转换是难题? 搜狗浏览器即开即看

由于PDF文件兼容性相当广泛,越来越多的电子图书、产品说明、公司文告、网络资料、电子邮件选择开始使用这种格式来进行内容的展示,以便给用户更好的再现原稿的细节,但需要下载专用阅读器进行转化才能浏览的问题...

彻底搞懂 Netty 线程模型

点赞再看,养成习惯,微信搜一搜【...

2022通俗易懂Redis的线程模型看完就会

Redis真的是单线程吗?我们一般说Redis是单线程,是指Redis的网络IO和键值对操作是一个线程完成的,这就是Redis对外提供键值存储服务的主要流程。Redis的其他功能,例如持久化、异步删除...

实用C语言编程(第三版)高清PDF

编写C程序不仅仅需要语法正确,最关键的是所编代码应该便于维护和修改。现在有很多介绍C语言的著作,但是本书在这一方面的确与众不同,例如在讨论C中运算优先级时,15种级别被归纳为下面两条原则:需要的...

手拉手教你搭建redis集群(redis cluster)

背景:最近需要使用redis存储数据,但是随着时间的增加,发现原本的单台redis已经不满足要求了,于是就倒腾了一下搭建redistclusterredis集群。好了,话不多说,下面开始展示:...

记录处理登录页面显示: HTTP Error 503. The service is unavailable.

某天一个系统的登录页面无法显示,显示ServiceUnavailableHTTPError503.Theserviceisunavailable,马上登录服务器上查看IIS是否正常。...

黑道圣徒杀出地狱破解版下载 免安装硬盘版

游戏名称:黑道圣徒杀出地狱英文名称:SaintsRow:GatOutofHell游戏类型:动作冒险类(ACT)游戏游戏制作:DeepSilverVolition/HighVoltage...

Exchange Server 2019 实战操作指南

...