SAP 交货单行项目含税金额计算报cx_sy_zerodivide处理

业务背景:SAP交货单只有数量,没有金额,所以开发报表从订单的价格按数量计算交货单的金额。

用户反馈近期报表出现异常:

c 复制代码
****2012/12/12 清风雅雨 规格变更 Chg 修改开始
** 修改原因:由于余数为0时,可能会报错溢出。所以增加检查。
*          wa_alv-ttlwrx = ( wa_alv-lfimgr * wa_konv_pr01-kbetr / wa_konv_pr01-kpein +
*                  wa_alv-lfimgr * wa_konv_zr01-kbetr / wa_konv_zr01-kpein +
*                  wa_alv-lfimgr * wa_konv_pbxx-kbetr / wa_konv_pbxx-kpein +
*                  wa_alv-lfimgr * wa_konv_pb00-kbetr / wa_konv_pb00-kpein ) * ( 1 + p1 ) -
*                  wa_alv-lfimgr * wa_konv_zk01-kbetr / wa_konv_zk01-kpein +
*                  + wa_alv-lfimgr * wa_konv_zk03-kbetr / wa_konv_zk03-kpein.
      TRY.
          wa_alv-ttlwrx = ( wa_alv-lfimgr * wa_konv_pr01-kbetr / wa_konv_pr01-kpein +
                  wa_alv-lfimgr * wa_konv_zr01-kbetr / wa_konv_zr01-kpein +
                  wa_alv-lfimgr * wa_konv_pbxx-kbetr / wa_konv_pbxx-kpein +
                  wa_alv-lfimgr * wa_konv_pb00-kbetr / wa_konv_pb00-kpein ) * ( 1 + p1 ) -
                  wa_alv-lfimgr * wa_konv_zk01-kbetr / wa_konv_zk01-kpein +
                  + wa_alv-lfimgr * wa_konv_zk03-kbetr / wa_konv_zk03-kpein.
        CATCH cx_sy_zerodivide.
          IF p_jk <> 'X'.
            MESSAGE s000 WITH '交货单' wa_alv-vbeln '被0除请检查定价数量'.
          ENDIF.
          wa_alv-ttlwrx = 0.
      ENDTRY.
****2012/12/12 清风雅雨  规格变更 Chg 修改结束

当年年少不成熟,前台报cx_sy_zerodivide错误,就采用把异常CATCH后直接前台显示,并把值赋为0,而现在用户需要知道准确的值 ,时隔13年,再一次调查:

由于ZK01折让价格 没有价格单位,验证一下:

c 复制代码
REPORT  ztmp_test2.
DATA wa_konv_zk01 TYPE konv.
DATA l_kbetr TYPE konv-kbetr.
wa_konv_zk01-kbetr = 0.
wa_konv_zk01-kpein = 0.
l_kbetr = wa_konv_zk01-kbetr / wa_konv_zk01-kpein.
WRITE : l_kbetr.

输出0

c 复制代码
REPORT  ztmp_test2.
DATA wa_konv_zk01 TYPE konv.
DATA l_kbetr TYPE konv-kbetr.
wa_konv_zk01-kbetr = 1.
wa_konv_zk01-kpein = 0.
l_kbetr = wa_konv_zk01-kbetr / wa_konv_zk01-kpein.
WRITE : l_kbetr.

报cx_sy_zerodivide

总结:

1、0/0 = 0

2、有值/0 报cx_sy_zerodivide

问题找到了怎么解决?

检查KONV ZK01类型,13年才有38条记录。所以问题一直没有爆露。

解决方案:

针对没有价格单位kpein的计算逻辑:

交货单XXX金额= 交货单数量/订单数量 x 订单条件金额

而有价格单位的计算逻辑:

交货单XXX金额= 交货单数量 x 订单条件金额/订单条件价格单位

c 复制代码
IF wa_konv_zk01-kpein NE 0.
        zk01tmp = wa_alv-lfimgr * wa_konv_zk01-kbetr / wa_konv_zk01-kpein.
ELSE.
        zk01tmp = wa_alv-lfimgr / wa_alv-kwmeng * wa_konv_zk01-kbetr
ENDIF.

比如本例:

如果交货5万则5/540000=40000
如果交货2万则2/5
40000=16000

同样的算法取其他5个定价条件:

复制代码
	pr01tmp,
    zr01tmp,
    pbxxtmp,
    pb00tmp,
    zk03tmp.

这样可以取到6个正确的定价条件的值,再进行交货单行项目含税金额的计算

c 复制代码
  wa_alv-ttlwrx = ( pr01tmp + zr01tmp + pbxxtmp + pb00tmp ) * ( 1 + p1 ) -
                    zk01tmp + zk03tmp.
相关推荐
SAP小崔说事儿14 小时前
SAP B1 批量应用用户界面配置模板
java·前端·ui·sap·b1·无锡sap
SAP小崔说事儿18 小时前
SAP B1 &钉钉集成解决方案—采购申请单审批
钉钉·sap·hana·无锡sap·sap和钉钉集成·sap集成开发·erp集成开发
study_小达人4 天前
hana一体机/hana数据库
sap·hana数据库
study_小达人4 天前
SAP--S4/HANA
sap·s4/hana
LilySesy6 天前
【与AI+】英语day1——ABAP基础与数据类型
开发语言·ai·sap·abap
LilySesy7 天前
【案例总结】震撼巨作——SAP连接钉钉WEBHOOK
运维·人工智能·ai·钉钉·sap·abap·webhook
Henry-SAP7 天前
SAP MRP功能与配置业务解析
sap·erp
Henry-SAP7 天前
SAP Fiori FES核心组件解析
sap·erp
Odoo老杨11 天前
成长型企业 ERP 系统选型:SAP 与 Odoo 免费开源 ERP 全面对比
sap·odoo·erp·中小企业数字化
阿达_优阅达11 天前
告别手工对账:xSuite 如何帮助 SAP 企业实现财务全流程自动化?
服务器·数据库·人工智能·自动化·sap·企业数字化转型·xsuite