点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)我需要从bseg获取lifnr数...
点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)我需要从bseg获取lifnr数...
加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)
我需要从bseg获取lifnr数据并链接lfa1-lifnr,并将STCD3显示为GST IN COLUMN
我有一些状况
1。 如果lifnr行为空,则表示已输入HKONT字段,并在供应商编号
中显示我已经链接了lifnr以显示STCD3。
2。 在使用
时使用键LIFNR = WA_FINAL1-HKONT将表IT_LFA1读入WA_LFA1。
sy-subrc = 4错误即将出现
将IT_BSEG放入WA_BSEG中。
WA_FINAL1-BELNR = WA_BSEG-BELNR。
WA_FINAL1-GJAHR = WA_BSEG-GJAHR。
WA_FINAL1-MWSKZ = WA_BSEG-MWSKZ。
WA_FINAL1- WRBTR = WA_BSEG-WRBTR。
如果WA_BSEG-TCODE NE'MIRO'。
WA_FINAL1-LIFNR = WA_BSEG-LIFNR。
如果WA_BSEG-LIFNR =''。< br> WA_FINAL1-LIFNR = WA_BSEG-HKONT。 " WA_BSEG-HKONT。
ELSEIF
WA_FINAL1-LIFNR = WA_BSEG-LIFNR。
ENDIF。
ELSEIF WA_BSEG-TCODE NE'FV60'。
WA_FINAL1-LIFNR = WA_BSEG-LIFNR。如果WA_BSEG-LIFNR =''。
WA_FINAL1-LIFNR = WA_BSEG-HKONT。
ELSEIF
WA_FINAL1-LIFNR = WA_BSEG-LIFNR。
ENDIF。
ENDIF。
WA_FINAL1-MATNR = WA_BSEG-MATNR。
WA_FINAL1-WERKS = WA_BSEG-WERKS。
WA_FINAL1-MENGE = WA_BSEG-MENGE。< br> WA_FINAL1-MEINS = WA_BSEG-MEINS。
WA_FINAL1-EBELN = WA_BSEG-EBELN。
WA_FINAL1-EBELP = WA_BSEG-EBELP。
WA_FINAL1-HSN_SAC = WA_BSEG-HSN_SAC。
WA_FINAL1-BUKRS = WA_BSEG-BUKRS。
如果WA_BSEG-BSCHL EQ为'89'。
WA_FINAL1-SEG_HKONT = WA_BSEG-HKONT。
ENDIF。
读取表IT_BKPF并通过键BELNR = WA_BKPF WA_BSEG-BELNR
GJAHR = WA_BSEG-GJAHR二进制搜索。
如果WA_FINAL1-MWSKZ ='R *'。
WA_FINAL1-TAX_DEC ='RCM'。
ELSEIF WA_FINAL1-MWSKZ NE'R *' 。
WA_FINAL1-TAX_DEC ='TAXABLE – GST'。
ENDIF。
如果SY-SUBRC =0。
WA_FINAL1-BELNR = WA_BKPF-BELNR。
WA_FINAL1-GJAHR = WA_BKPF-GJAHR。
WA_FINAL1-BLDAT = WA_BKPF-BLDAT。
WA_FINAL1-BUDAT = WA_BKPF-BUDAT。
WA_FINALK-TCODE = WAB
WA_FINAL1-XBLNR = WA_BKPF-XBLNR。
WA_FINAL1-WAERS = WA_BKPF-WAERS。
WA_FINAL1-KURSF = WA_BKPF-KURSF。
WA_FINAL1-AWKEY = WA_BKPF-AWKEY。
< br>呼叫功能'ISP_GET_MONTH_NAME'
导出
日期= WA_FINAL1-BLDAT
语言= SY-LANGU
* MONTH_NUMBER ='00'
IMPORTING
* LANGU_BACK =
LONGTEXT = WA_FINAL1-MONTHS
*短文本=
例外情况
CALENDAR_ID = 1
DATE_ERROR = 2
NOT_FOUND = 3
WRONG_INPUT = 4
其他=5。
IF SY -SUBRC <> 0.
*在此处实施适当的错误处理
ENDIF。
ENDIF。
IF WA_FINAL1-TCODE EQ'MIRO'。
通话功能'TEXT_SPLIT '
导出
长度= 10
文本= WA_FINAL1-AWKEY
" AS_CHARACTER =
导入
线= WA_FINAL1-DOCNO
REST = WA_FINAL1-DOCYR。
否则 。
WA_FINAL1-DOCNO = W A_FINAL1-BELNR。
ENDIF。
用键EBELN = WA_BSEG-EBELN将表IT_EKKO读入WA_EKKO。 "二进制搜索。
如果WA_FINAL1-TCODE EQ'MIRO'。
如果SY-SUBRC =0。
WA_FINAL1-BSART = WA_EKKO-BSART。
< br> IF WA_EKKO-BSART EQ'ZVR'。
WA_FINAL1-PUR_RET ='返回'。
ELSE。" WA_EKKO-BSART NE'ZVR'。
WA_FINAL1-PUR_RET ='购买'。
ENDIF。
ENDIF。
ENDIF。
读取表IT_MAKT到WA_MAKT中,键MATNR = WA_FINAL1-MATNR。
如果SY-SUBRC = 0。
WA_FINAL1-MAKTX = WA_MAKT-MAKTX。
ENDIF。
用键MATNR = WA_BSEG-MATNR将表IT_MARC读入WA_MARC
WERKS = WA_BSEG-WERKS二进制搜索。 > IF SY-SUBRC =0。
WA_FINAL1-STEUC = WA_MARC-STEUC。
ENDIF。
将表IT_LFA1读入WA_LFA1中,键为LIFNR = WA_FINAL1-LIFNR。
IF SY-SUBRC = 0。
WA_FINAL1-NAME1 = WA_LFA1-NAME1。
WA_FINAL1-REGIO = WA_LFA1-REGIO。
WA_FINAL1-STCD3 = WA_LFA1-STCD3。
ENDIF。
使用键LIFNR = WA_FINAL1-HKONT将表IT_LFA1读入WA_LFA1。
如果SY-SUBRC =0。
WA_FIN AL1-NAME1 = WA_LFA1-NAME1。
WA_FINAL1-REGIO = WA_LFA1-REGIO。
WA_FINAL1-STCD3 = WA_LFA1-STCD3。
ENDIF。
读表IT_SKAT 使用键SAKNR = WA_BSEG-HKONT进入WA_SKAT。
如果WA_FINAL1-NAME1 =''。
WA_FINAL1-SAKNR = WA_SKAT-SAKNR。
WA_FINAL1-NAME1 = WA_SKAT- TXT20。
ENDIF。
如果SY-SUBRC =0。" WA_LFA1-NAME1 ="。
WA_FINAL1-SAKNR = WA_SKAT-SAKNR。
WA_FINAL1-TXT20 = WA_SKAT-TXT20。
ENDIF。
使用键MWSKZ = WA_FINAL1-MWSKZ将表IT_T007S读入WA_T007S。 "二进制搜索。
如果SY-SUBRC =0。
WA_FINAL1-TEXT1 = WA_T007S-TEXT1。
ENDIF。
读取表IT_T001W并通过按键操作读入WA_T001W = WA_BSEG- WERKS二进制搜索。
如果SY-SUBRC =0。
WA_FINAL1-T00_REGIO = WA_T001W-REGIO。
ENDIF。
在IT_BSET处插入WA_BSET,其中BUKRS = WA_BSEG-BUKRS AND
BELNR = WA_BSEG-BELNR AND
GJAHR = WA_BSEG-GJAHR。
如果WA_BSET-KSCHL ='JIIG'。
WA_FINAL1-VAL_IGST = WA_BSET-FWSTE。
WA_FINAL1-PER_IGST = WA_BSET-KBETR/10。
ENDIF。
如果WA_BSET-KSCHL ='JICG'。
WA_FINAL1-VAL_CGST = WA_BSET-FWSTE。
WA_FINAL1-PER_CGST = WA_BSET-KBETR/10。
ENDIF。
> IF WA_BSET-KSCHL ='JISG'。
WA_FINAL1-VAL_SGST = WA_BSET-FWSTE。
WA_FINAL1-PER_SGST = WA_BSET-KBETR/10。
ENDIF。
IF WA_FINAL1-VAL_IGST NE 0。
WA_FINAL1-GST_RET ='IGST'。
ENDIF。
如果WA_FINAL1-VAL_IGST = 0.
WA_FINAL1-GST_RET ='GST'。
ENDIF。
*如果WA_FINAL1-VAL_IGST NE'0'。
* WA_FINAL1-GST_RET ='IGST'。
* ENDIF。
*如果WA_FINAL1-VAL_CGST NE为'0'。
* WA_FINAL1-GST_RET ='GST'。
* ENDIF。
ENDLOOP。
> WA_FINAL1-VAL_TOTAL = WA_FINAL1-VAL_IGST + WA_FINAL1-VAL_CGST + WA_FINAL1-VAL_SGST。
WA_FINAL1-TOT_GST = WA_FINAL1-PER_IGST + WA_FINAL1-PER_CGST + WA_FINAL1-PER_SGST。
SHIFT WA_FINAL1-MATNR左删除领先'0'。
将WA_FINAL1追加到IT_FINAL1。
清除WA_FINAL1。
ENDLOOP。
您好,
请只共享相关的代码片段,并使用copy-> paste作为text-> button" code"将其格式化:这将使每个人都更容易阅读
老实说,我看不到任务的问题:
这可以通过使用新的ABAP语法更理想的方式来实现,但是逻辑是相同的。
我假设您正在从BSEG中过滤所有相关的案例,因此您始终将LIFNR或HKONT与 LIFNR值
一周热门 更多>