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.
相关推荐
山茶花开时。8 天前
[SAP] SAP MM模块学习路径
sap·mm
stone082314 天前
SAP - 使用CL_FDT_XL_SPREADSHEET将Excel文档导入到内表
sap
雨天行舟18 天前
abap调用deepseek接口 v3.0
http·ai·sap·abap·聊天·deepseek
stone082320 天前
SAP FICO程序 - 会计科目余额报表
sap
Henry-SAP21 天前
ERP(SAP) MRP 业务视角全局流程解析
人工智能·sap·软件需求·erp·sap pp
小羔羊的官方学习账号23 天前
SAP中工单控制关键配置点
sap·pp
SAP_奥维奥科技23 天前
奥维奥助力花园乳业数字化转型落地 以SAP B1破解全产业链管理难题
sap·sap管理系统·sap business one·sap管理系统软件·sap实施服务商
sinat_3751122623 天前
ME_PROCESS_PO_CUST增强check
sap·abap·增强
Seele_10181 个月前
RAP - 报表示例
sap·abap
SAP_奥维奥科技1 个月前
破局传统制造,赋能智能转型——机加工企业智能工厂升级实施方案重磅出炉
sap·智能制造·sap管理系统·sap管理系统软件·sap实施服务商推荐