BAPI_PO_CREATE1 创建采购订单时价格的处理函数

When you create a purchase order, values I, U and D refer to the conditionsthat were derived automatically, that is, you can also use U and D already during the creation. When you change a purchase order, they also refer to existing conditions.

 

 

Prerequisite

 

You must implement Note 494759 in your system to use these functions.

 

 

Example A: CHANGE_ID = 'I'

 

You create a purchase order with BAPI_PO_CREATE1. The system shoulddetermine the conditions for item 10 automatically. In addition, however, you want to calculate 3 % freight costs. You use condition type FRA1 for the freight costs. Then tables POCOND and POCONDX must be filled with the following values:

 

 

           POCOND-ITM_NUMBER = 10 (item number)

 

           POCOND-COND_TYPE = FRA1 (condition type)

 

           POCOND-COND_VALUE = 3.0 (condition value)

 

           POCOND-CURRENCY = %

 

           POCOND-CHANGE_ID = I

 

 

           POCONDX-ITM_NUMBER = 10

 

           POCONDX-ITM_NUMBERX = X

 

           POCONDX-COND_TYPE = X

 

           POCONDX-COND_VALUE = X

 

           POCONDX-CURRENCY = X

 

           POCONDX-CHANGE_ID = X

 

 

Example B: CHANGE_ID = 'U'

 

You create a purchase order with BAPI_PO_CREATE1. The system determines a price (condition type PB00) of 90 EUR for item 10. You want to change the 90 EUR to 100 EUR. To do this, fill tables POCOND and POCONDX with the following values:

 

 

           POCOND-ITM_NUMBER = 10

 

           POCOND-COND_TYPE = PB00

 

           POCOND-COND_VALUE = 100

 

           POCOND-CURRENCY = EUR

 

           POCOND-CHANGE_ID = U

 

 

           POCONDX-ITM_NUMBER = 10

 

           POCONDX-ITM_NUMBERX = X

 

           POCONDX-COND_TYPE = X

 

           POCONDX-COND_VALUE = X

 

           POCONDX-CURRENCY = X

 

           POCONDX-CHANGE_ID = X

 

 

Example C: CHANGE_ID = 'D'

 

Now you want to use BAPI_PO_CHANGE to delete the freight costs added in example A again. To do this, fill tables POCOND and POCONDX with the following values:

 

 

           POCOND-ITM_NUMBER = 10

 

           POCOND-COND_TYPE = FRA1

 

           POCOND-CHANGE_ID = D

 

 

           POCONDX-ITM_NUMBER = 10

 

           POCONDX-ITM_NUMBERX = X

 

           POCONDX-COND_TYPE = X

 

           POCONDX-CHANGE_ID = X

 

 

It is not necessary to transfer additional item data. Theonlyinformation that must be transferred in addition to the condition tables is the purchase order number (PURCHASEORDER field).

 

 

1. POCONDHEADER-CHANGE_ID

The header conditionsaretransferred using the POCONDHEADER table. Here, the CHANGE_ID field has the same function as in the POCOND table (see above).

 

 

Prerequisite

 

You must implement Note 494759 in your system to use these functions.

 

 

Example

 

You create a purchase order with several items and want to distributethe amount 100 EUR to the items on a percentage basis. You defined condition type HB00 for this purpose. Then the POCONDHEADER and POCONDHEADERX tables must be filled as follows:

 

 

           POCONDHEADER-COND_TYPE = HB00

 

           POCONDHEADER-COND_VALUE = 100

 

           POCONDHEADER-CURRENCY = EUR

 

           POCONDHEADER-CHANGE_ID = I

 

 

           POCONDHEADERX-COND_TYPE = X

 

           POCONDHEADERX-COND_VALUE = X

 

           POCONDHEADERX-CURRENCY = X

 

           POCONDHEADERX-CHANGE_ID = X

BAPI_PO_CREATE1是一个针对事务码ME21N的函数模块,用于创建采购订单。它接受抬头和行项目作为输入参数,并根据这些参数创建采购订单[^2]。 在使用BAPI_PO_CREATE1,需要注意以下几点: 1. 抬头数据:需要提供采购订单的抬头信息,例如供应商、采购组织、采购组等。 2. 行项目数据:需要提供采购订单的行项目信息,例如物料号、数量、价格等。 3. lt_poitem-ematerial字段:在同一个BAPI COMMIT中多次调用BAPI_PO_CREATE1,需要赋值该字段。如果不赋值,系统会自动将其值设置为lt_poitem-material的值,并在后续调用中记忆该值。如果不正确地赋值该字段,可能会导致后续的BAPI调用报错[^1]。 下面是一个使用BAPI_PO_CREATE1创建采购订单的示例代码: ```python import pyrfc # 创建RFC连接 conn = pyrfc.Connection(user='username', passwd='password', ashost='host', sysnr='00', client='client') # 准备抬头数据 header_data = { 'COMP_CODE': '0001', 'DOC_TYPE': 'NB', 'VENDOR': '10000001', # 其他抬头字段... } # 准备行项目数据 item_data = [ { 'PO_ITEM': '00010', 'MATERIAL': 'MATERIAL1', 'QUANTITY': 10, # 其他行项目字段... }, { 'PO_ITEM': '00020', 'MATERIAL': 'MATERIAL2', 'QUANTITY': 20, # 其他行项目字段... }, # 其他行项目... ] # 调用BAPI_PO_CREATE1创建采购订单 result = conn.call('BAPI_PO_CREATE1', POHEADER=header_data, POITEM=item_data) # 检查返回结果 if result['RETURN'][0]['TYPE'] == 'E': print('创建采购订单失败:', result['RETURN'][0]['MESSAGE']) else: print('创建采购订单成功:', result['RETURN'][0]['MESSAGE']) # 关闭RFC连接 conn.close() ``` 请注意,上述示例代码中的参数值需要根据实际情况进行替换。另外,还需要安装pyrfc库来进行RFC连接的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SAP剑客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值