首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

采购订单含税价实现方式

在很多企业里,采购跟供应商谈定的价格是含税价。采购订单价格一般都是通过含税价来实现的,但是SAP的标准功能要求采购订单上面输入的价格是一个净价,即不含税价。如果客户不使用净价做维护,那么就要使用含税价。

实现方式可以考虑:采购单输入的采购价格类型是PB00或者PBXX,是一个含税价。只要再做另外一个条件类型把税算出来,作为一个折扣项减去,最后得到的就是净价了。

按照这个思路我们来做。首先做一个条件类型ZTAX,折扣型的,负数。

然后再把这个折扣的条件类型放到定价过程里面,例如就使用标准的RM0000

有几个地方要注意:

1. From - to这里面要得到的是含税的总价。就直接参考step 1 -即PB00或PBXX

2. Subtotal一定要写9,9才会计算到net value里面去

3. 新建一个calculation formula,比如905.因为这个条件类型需要我们通过税码自己计算出来,而不是通过存取顺序维护条件记录的方式计算出来。

下面就是公式的内容了。

*&---------------------------------------------------------------------*

*&     Form  FRM_KONDI_WERT_905

*&---------------------------------------------------------------------*

*      text

*----------------------------------------------------------------------*

FORM frm_kondi_wert_905.

DATA: l_kbetr LIKE konp-kbetr.    "Tax Rate

DATA: l_krech LIKE t685a-krech.   "Inclusive or Exclusive

DATA: l_knumh LIKE a003-knumh.    "Condition Record Number

DATA: l_kschl LIKE a003-kschl.    "Condition Type

DATA: l_kappl(2) TYPE c VALUE 'TX'. "Application

* Get condition type and condition record

SELECT SINGLE knumh kschl

        FROM a003

        INTO (l_knumh,l_kschl)

       WHERE kappl = l_kappl

         AND aland = komk-aland

         AND mwskz = komp-mwskz.

IF sy-subrc = 0.

* Get condition record value

  SELECT SINGLE kbetr

         INTO l_kbetr

         FROM konp

         WHERE knumh = l_knumh.

  IF sy-subrc = 0.

   SELECT SINGLE krech

           INTO l_krech

           FROM t685a

          WHERE kschl = l_kschl.

* Set Condition Value

    IF sy-subrc = 0.

     IF l_krech = 'A'. "Tax Excluded

       xkwert = -1 * xkomv-kawrt * l_kbetr / ( 100000 + l_kbetr ).

     ELSEIF l_krech = 'I'. "Tax Included

       xkwert = -1 * xkomv-kawrt * l_kbetr  / 100000.

     ENDIF.

   ENDIF.

   l_kschl = xkomv-kschl.

* Set Condition Amount

    LOOP AT xkomv WHERE kschl = l_kschl.

     xkomv-kbetr = l_kbetr * -1.

   ENDLOOP.

  ELSE.

* Set Condition Value

   xkwert = 0.

   l_kschl = xkomv-kschl.

* Set Condition Amount

    LOOP AT xkomv WHERE kschl = l_kschl.

     xkomv-kbetr = 0.

   ENDLOOP.

  ENDIF.

ENDIF.

ENDFORM.                 "FRM_KONDI_WERT_905

然后就可以了,做个采购订单,变换税率,ZTAX就会自动根据税码里面配置的金额发生变化。

这个公式里面涉及到了一个'A'和'I'的问题。A是价外税,I是价内税。举例来说:同样100块的含税价,17%的税率,如果按A的方式,那么税就是100/1.17*0.17 = 14.53,净价就是85.47.而如果是I的方式,税就是100*0.17 = 17,净价就是83

一般I这种方式在未加工农产品采购的时候会使用,多半是13%的税率,叫扣除率。

V1税码:价外税15%

输入含税价115,得到净价100。

W1税码价内税 13%

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20200715A02YLH00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券