1业务说明

当寻源后,将寻源结果汇总,并创建采购申请,之后据此创建采购订单。

此文档使用BAPI:BAPI_REQUISITION_CREATE创建采购申请

2前台实现

事务代码:ME51N

3代码实现

3.1调用BAPI

传入相应的行项目数据

导入BAPI

3.2扩展字段

在EBAN表中增加自定义字段

在结构BAPI_TE_REQUISITION_ITEM中定义采购申请项目编号字段,该字段必须有,也必须传值。将结构CI_EBANDB引用进来。

将行项目和申请原因等字段传入结构中,再赋值给BAPI扩展内表GT_EXTENSION,传入BAPI中

创建后,采购申请原因已经传入成功

3.3创建服务类采购申请

创建服务类申请没有物料号,输入相应的数据

首先创建三个变量,用于存储几个编号

在行项目中需要传入软件包编号

输入总账科目和成本中心,并赋值序列号

在服务行中,先输入软件父包

再添加软件子包

在REQUISITION_SRV_ACCASS_VALUES中添加软件子包对应的信息

最后调用BAPI创建成功

软件包的流水号维护在这个对象中,但是在BAPI赋值的时候,直接赋值0000000001即可,如果通过流水号获取赋值进去,反倒不成功。

原因猜测可能是,系统每次都自动获取,不采用付的值,但是如果使用了流水号函数就打乱了系统自己赋值的逻辑。所以在BAPI中赋值0000000001和子包在此上+1,将服务行的父包和子包关联起来即可。

采购申请保存在EBAN表中,服务保存在ESLL表中。

3.4源代码

"-----------------------------@斌将军-----------------------------
DATA:LV_NUMBER TYPE BAPIMEREQHEADER-PREQ_NO,
GT_ITEM TYPE TABLE OF BAPIEBANC,
GS_ITEM TYPE BAPIEBANC,
GT_EXTENSION TYPE TABLE OF BAPIPAREX,
GS_EXTENSION TYPE BAPIPAREX,
GT_RETURN TYPE TABLE OF BAPIRETURN,
GS_RETURN TYPE BAPIRETURN. DATA:LV_MESSAGE TYPE CHAR200,
LV_CHECK TYPE CHAR1. CLEAR:GS_ITEM.
GS_ITEM-PREQ_ITEM = '10'."行项目号
GS_ITEM-DOC_TYPE = 'CKSG'."采购申请凭证类型
GS_ITEM-PUR_GROUP = 'C10'."采购组
GS_ITEM-MATERIAL = '405481'."物料号
GS_ITEM-PLANT = '2000'. "工厂
GS_ITEM-STORE_LOC = '2007'. "库存地点
GS_ITEM-QUANTITY = '1'."数量
GS_ITEM-PREQ_DATE = SY-DATUM."需求日期
GS_ITEM-TRACKINGNO = ''."需求跟踪号
GS_ITEM-FIXED_VEND = ''."固定供应商
GS_ITEM-PREQ_NAME = 'SRM'."申请者
GS_ITEM-VAL_TYPE = 'CR'."评估类型
GS_ITEM-DELIV_DATE = '20200129'."交货日期
GS_ITEM-UNIT = 'PC'."计量单位
CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
EXPORTING
INPUT = GS_ITEM-MATERIAL"物料号
IMPORTING
OUTPUT = GS_ITEM-MATERIAL.
CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
EXPORTING
INPUT = GS_ITEM-FIXED_VEND"固定供应商
IMPORTING
OUTPUT = GS_ITEM-FIXED_VEND. CALL FUNCTION 'CONVERSION_EXIT_CUNIT_INPUT'
EXPORTING
INPUT = GS_ITEM-UNIT"计量单位
LANGUAGE = SY-LANGU
IMPORTING
OUTPUT = GS_ITEM-UNIT.
APPEND GS_ITEM TO GT_ITEM. CLEAR:GS_EXTENSION.
GS_EXTENSION-STRUCTURE = 'BAPI_TE_REQUISITION_ITEM'.
GS_EXTENSION-VALUEPART1 = GS_ITEM-PREQ_ITEM && GS_ITEM-PREQ_NAME."申请原因
APPEND GS_EXTENSION TO GT_EXTENSION. CLEAR:LV_NUMBER.
CALL FUNCTION 'BAPI_REQUISITION_CREATE'
EXPORTING
* SKIP_ITEMS_WITH_ERROR = gt_item
AUTOMATIC_SOURCE = ' '
IMPORTING
NUMBER = LV_NUMBER
TABLES
REQUISITION_ITEMS = GT_ITEM
* REQUISITION_ACCOUNT_ASSIGNMENT =
* REQUISITION_ITEM_TEXT =
* REQUISITION_LIMITS =
* REQUISITION_CONTRACT_LIMITS =
* REQUISITION_SERVICES =
* REQUISITION_SRV_ACCASS_VALUES =
RETURN = GT_RETURN
* REQUISITION_SERVICES_TEXT =
* REQUISITION_ADDRDELIVERY =
EXTENSIONIN = GT_EXTENSION. LV_CHECK = 'S'.
LOOP AT GT_RETURN INTO GS_RETURN WHERE TYPE = 'A' OR TYPE = 'E'.
LV_MESSAGE = LV_MESSAGE && GS_RETURN-MESSAGE.
LV_CHECK = 'E'.
ENDLOOP. IF LV_CHECK = 'S'.
CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
EXPORTING
WAIT = 'X'.
WRITE:LV_NUMBER.
ELSE.
CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.
ENDIF. ------------------服务类采购申请源代码---------------------
*&---------------------------------------------------------------------*
*& Report ZLCCTEST019
*&
*&---------------------------------------------------------------------*
*&
*&
*&---------------------------------------------------------------------*
REPORT ZLCCTEST019. DATA:GT_ITEM TYPE TABLE OF BAPIEBANC,
GS_ITEM TYPE BAPIEBANC,
GT_SER TYPE TABLE OF BAPIESLLC,
GS_SER TYPE BAPIESLLC,
GT_SER_VALUES TYPE TABLE OF BAPIESKLC,
GS_SER_VALUES TYPE BAPIESKLC,
GT_WBS TYPE TABLE OF BAPIEBKN,
GS_WBS TYPE BAPIEBKN,
GT_RETURN TYPE TABLE OF BAPIRETURN,
L_NO1 TYPE BAPIMEREQHEADER-PREQ_NO,
LV_MESSAGE TYPE CHAR200,
LV_PCKG_NO TYPE BAPIEBANC-PCKG_NO VALUE 0000000001, "软件包编号
LV_ACCASSERIAL_NO TYPE BAPIEBKN-SERIAL_NO VALUE 01, "序列号
LV_LINE_NO TYPE BAPIESLLC-LINE_NO VALUE 1. "内部行编号 GS_ITEM-PREQ_ITEM = '00010'.
GS_ITEM-DOC_TYPE = 'CKSR'.
GS_ITEM-PLANT = '2000'.
GS_ITEM-QUANTITY = '1'."数量
GS_ITEM-PREQ_NAME = '123'."申请者
GS_ITEM-UNIT = 'LE'."计量单位
GS_ITEM-ACCTASSCAT = 'W'."科目分配类别
GS_ITEM-ITEM_CAT_EXT = 'D'."科目分配类别
GS_ITEM-SHORT_TEXT = '123'."短文本
GS_ITEM-MAT_GRP = '&DB001'."物料组
GS_ITEM-PREQ_DATE = '20210307'."需求日期
GS_ITEM-DELIV_DATE = '20210307'."需求日期
GS_ITEM-DELIV_DATE = '20210307'."需求日期
GS_ITEM-PCKG_NO = LV_PCKG_NO."软件包编号
GS_ITEM-GR_IND = 'X'.
GS_ITEM-GR_NON_VAL = 'X'.
GS_ITEM-IR_IND = 'X'.
APPEND GS_ITEM TO GT_ITEM. GS_WBS-PREQ_ITEM = '00010'.
GS_WBS-SERIAL_NO = LV_ACCASSERIAL_NO.
GS_WBS-G_L_ACCT = '6601039900'.
GS_WBS-COST_CTR = '0BE000'.
APPEND GS_WBS TO GT_WBS. GS_SER-PCKG_NO = LV_PCKG_NO."软件包编号
GS_SER-LINE_NO = LV_LINE_NO."内部行编号
GS_SER-OUTL_IND = 'X'."标识符:概要行
GS_SER-SUBPCKG_NO = LV_PCKG_NO + 1."分包编号
GS_SER-FROM_LINE = 1."下限
APPEND GS_SER TO GT_SER. CLEAR:GS_SER.
GS_SER-PCKG_NO = LV_PCKG_NO + 1."软件包编号
GS_SER-LINE_NO = LV_LINE_NO + 1."内部行编号
GS_SER-EXT_LINE = 0000000010."行号
GS_SER-QUANTITY = 1."数量
GS_SER-BASE_UOM = 'LE'."计量单位
GS_SER-PRICE_UNIT = 1."价格单位
GS_SER-NET_VALUE = NETPR * QUANTITY."净值
GS_SER-SHORT_TEXT = 123."短文本
GS_SER-MATL_GROUP = '&DB001'."物料组
GS_SER-GR_PRICE = 10."总价
APPEND GS_SER TO GT_SER. GS_SER_VALUES-PCKG_NO = LV_PCKG_NO + 1."软件包编号
GS_SER_VALUES-LINE_NO = LV_LINE_NO + 1."内部行编号
GS_SER_VALUES-SERNO_LINE = 01."服务行
GS_SER_VALUES-SERIAL_NO = GS_SER_VALUES-SERNO_LINE."帐户分配的顺序编号
GS_SER_VALUES-PERCENTAGE = 100."帐户分配值分配百分比
GS_SER_VALUES-NET_VALUE = NETPR * QUANTITY."项目净值
GS_SER_VALUES-QUANTITY = 1."数量带标记
APPEND GS_SER_VALUES TO GT_SER_VALUES. CALL FUNCTION 'BAPI_REQUISITION_CREATE'
EXPORTING
* SKIP_ITEMS_WITH_ERROR = gt_item
AUTOMATIC_SOURCE = ' '
IMPORTING
NUMBER = L_NO1
TABLES
REQUISITION_ITEMS = GT_ITEM
REQUISITION_ACCOUNT_ASSIGNMENT = GT_WBS
* REQUISITION_ITEM_TEXT =
* REQUISITION_LIMITS =
* REQUISITION_CONTRACT_LIMITS =
REQUISITION_SERVICES = GT_SER
REQUISITION_SRV_ACCASS_VALUES = GT_SER_VALUES
RETURN = GT_RETURN
* REQUISITION_SERVICES_TEXT =
* REQUISITION_ADDRDELIVERY =
* EXTENSIONIN = GT_EXTENSION1
. CLEAR:LV_MESSAGE.
LOOP AT GT_RETURN INTO DATA(GL_RETURN) WHERE TYPE = 'E' OR TYPE = 'A'.
CONCATENATE LV_MESSAGE '/' GL_RETURN-MESSAGE INTO LV_MESSAGE.
CLEAR GL_RETURN.
ENDLOOP.
IF LV_MESSAGE IS INITIAL AND L_NO1 IS NOT INITIAL.
* 提交事务
CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
EXPORTING
WAIT = 'X'.
ELSE.
CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK' .
ENDIF. WRITE :L_NO1.
"-----------------------------@斌将军-----------------------------

定期更文,欢迎关注

 
 
 
此页面的语言为英语
 
翻译为中文(简体)
 
 
 
 
  • 中文(简体)
  • 中文(繁体)
  • 丹麦语
  • 乌克兰语
  • 乌尔都语
  • 亚美尼亚语
  • 俄语
  • 保加利亚语
  • 克罗地亚语
  • 冰岛语
  • 加泰罗尼亚语
  • 匈牙利语
  • 卡纳达语
  • 印地语
  • 印尼语
  • 古吉拉特语
  • 哈萨克语
  • 土耳其语
  • 威尔士语
  • 孟加拉语
  • 尼泊尔语
  • 布尔语(南非荷兰语)
  • 希伯来语
  • 希腊语
  • 库尔德语
  • 德语
  • 意大利语
  • 拉脱维亚语
  • 挪威语
  • 捷克语
  • 斯洛伐克语
  • 斯洛文尼亚语
  • 旁遮普语
  • 日语
  • 普什图语
  • 毛利语
  • 法语
  • 波兰语
  • 波斯语
  • 泰卢固语
  • 泰米尔语
  • 泰语
  • 海地克里奥尔语
  • 爱沙尼亚语
  • 瑞典语
  • 立陶宛语
  • 缅甸语
  • 罗马尼亚语
  • 老挝语
  • 芬兰语
  • 英语
  • 荷兰语
  • 萨摩亚语
  • 葡萄牙语
  • 西班牙语
  • 越南语
  • 阿塞拜疆语
  • 阿姆哈拉语
  • 阿尔巴尼亚语
  • 阿拉伯语
  • 韩语
  • 马尔加什语
  • 马拉地语
  • 马拉雅拉姆语
  • 马来语
  • 马耳他语
  • 高棉语
 
随时将英语翻译为中文(简体)PRO
一律不翻译英语
一律不翻译i.cnblogs.com

ME51N 创建采购申请的更多相关文章

  1. 【ABAP系列】SAP ABAP BAPI_REQUISITION_CREATE创建采购申请

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP BAPI_RE ...

  2. ME51N, ME52N 创建采购申请的一个BADI

    ME51N ME52N创建修改采购申请时的一个BADI (2013-07-11 16:50:58) 转载▼ 标签: 采购申请 me51n me52 badi me_process_req_cust 分 ...

  3. SAP MM 无料号采购申请单中'评估价格'之填写

    SAP MM 无料号采购申请单中'评估价格'之填写 1),SAP系统中,采购申请里的'评估价格'来源有二, a)如果是有物料号的采购,则该价格来自于物料主数据里里的成本价(移动平均价或者标准价),自动 ...

  4. 详解EBS接口开发之采购申请导入

    更多内容可以参考我的博客  详解EBS接口开发之采购订单导入 http://blog.csdn.net/cai_xingyun/article/details/17114697 /*+++++++ ...

  5. 函数使用二:采购申请BAPI_PR_CREATE

    REPORT YTEST01. ***************************采购申请创建*****************************begin DATA:LV_BANFN TY ...

  6. ABAP-增强-MRP运行-根据工厂/父件/子件/供应商拆分采购申请

    最近有个业务需要,MRP运行过程中需要根据生产计划订单/子件/供应商对应关系来拆解采购申请. 1.具体实例: a.基础数据 整车物料:NL1G58420151001219 子件:00000000888 ...

  7. SAP-MM:创建采购组织、采购组

    创建采购组织 路径:SPRO – IMG – 企业结构 – 定义 – 物料管理 – 维护采购组织   操作: Step 1.点击"新条目". Step 2.维护"采购组织 ...

  8. SAP MM已经转成PO的采购申请Item依旧可以被删除?

    SAP MM已经转成PO的采购申请Item依旧可以被删除? 笔者测试发现,我们可以删除已产生PO的PR item, 系统只是给一个警告信息,不阻止保存. Purchase orders already ...

  9. SAP MM 根据采购订单反查采购申请?

    SAP MM 根据采购订单反查采购申请? 前日微信上某同行发来一个message,说是想知道如何通过采购订单号查询到其前端的采购申请号. 笔者首先想到去检查采购订单相关的常用报表ME2L/ME2M/M ...

  10. 【MM系列】SAP MM模块-收货自动创建采购订单

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]SAP MM模块-收货自动创建采购订 ...

随机推荐

  1. Ubuntu 20.04 使用 socat 转发特定端口

    安装socat apt install socat 根据需求确定要转发的端口 比如,我的需求是监听IPv6的某一TCP端口,并转发至局域网内某一特定主机,可以使用以下命令: socat TCP6-LI ...

  2. 【译】拥抱 SQL Server 2022 与 SSDT 17.8:揭示关键更新

    在数据库开发的动态场景中,SQL Server Data Tools(SSDT)是 Visual Studio 生态系统中数据库开发人员的强大工具.SSDT 17.8 包含在最新版本的 Visual ...

  3. jdk9模块化

    JDK 9是Java开发语言的一个重大版本.其中最令人兴奋的新特性之一是模块化系统.模块化系统提出了一种新的代码组织方式,它可以帮助开发人员更好地组织和管理代码,从而使Java应用程序更加可维护.可扩 ...

  4. Nginx的安装与运行

    前言:本文是基于虚拟机上的centOS 7对Nginx的安装,可以使用uname -a查看centOS系统版本,本文用来记录安装nginx的步骤和相关命令,方便日后使用时查看. 去官网https:// ...

  5. 使用ztncui配置私有化zerotier服务器

    众所周知,Zerotier-One是一个非常好的组建虚拟局域网的工具,可以以p2p的方式穿透NAT网络进行连接.但是在使用中也仍然存在着一些瑕疵,主要就是以下两点: 因为Zerotier官方提供的中心 ...

  6. pycharm设置Ctrl+鼠标滚轮放大缩小字体

    方式一: File --> setting --> Editor-->General,勾选. 方式二: 放大的设置 File --> setting --> Keymap ...

  7. 本地tomcat设置外网访问

    将host name中的localhost修改为自己电脑的IP地址,具体的IP地址可以在控制面板的网络和共享中心中进行查看, 打开tomcat的conf文件夹下的server.xml文件,将local ...

  8. Python——第二章:单引号(')、双引号(")、花括号 {}的用法及注意事项

    在Python中,字符串可以用单引号(')或双引号(")括起来,它们在用法上没有本质区别.你可以根据个人偏好来选择使用单引号或双引号来创建字符串. 例如: 使用单引号括起的字符串: prin ...

  9. 用AI在本地给.NET设计几张壁纸

    AI是当今和未来非常重要的技术领域之一,它在各个行业都有广泛的应用,如医疗保健.金融.教育.制造业等.学习AI可以让你了解和掌握未来技术发展的核心,并为未来的职业发展做好准备.现在有很多开源的Mode ...

  10. 通过鼠标拖拉获取图片原像素的两个点坐标vue

    <template> <div> <img class="no-drag" ref="image" src="https ...