根據TCODE找使用者出口的程式碼
TABLES : tstc, "SAP Transaction Codes
tadir, "Directory of Repository Objects
modsapt, "SAP Enhancements - Short Texts
modact, "Modifications
trdir, "System table TRDIR
tfdir, "Function Module
enlfdir, "Additional Attributes for Function Modules
tstct. "Transaction Code Texts
*&---------------------------------------------------------------------*
*& Variables
*&---------------------------------------------------------------------*
DATA : jtab LIKE tadir OCCURS 0 WITH HEADER LINE.
DATA : field1(30).
DATA : v_devclass LIKE tadir-devclass.
*&---------------------------------------------------------------------*
*& Selection Screen Parameters
*&---------------------------------------------------------------------*
SELECTION-SCREEN BEGIN OF BLOCK a01 WITH FRAME TITLE text-001.
SELECTION-SCREEN SKIP.
PARAMETERS : p_tcode LIKE tstc-tcode OBLIGATORY.
SELECTION-SCREEN SKIP.
SELECTION-SCREEN END OF BLOCK a01.[@more@]
*&---------------------------------------------------------------------*
*& Start of main program
*&---------------------------------------------------------------------*
START-OF-SELECTION.
* Validate Transaction Code
SELECT SINGLE * FROM tstc
WHERE tcode EQ p_tcode.
* Find Repository Objects for transaction code
IF sy-subrc EQ 0.
SELECT SINGLE * FROM tadir
WHERE pgmid = 'R3TR'
AND object = 'PROG'
AND obj_name = tstc-pgmna.
MOVE : tadir-devclass TO v_devclass.
IF sy-subrc NE 0.
SELECT SINGLE * FROM trdir
WHERE name = tstc-pgmna.
IF trdir-subc EQ 'F'.
SELECT SINGLE * FROM tfdir
WHERE pname = tstc-pgmna.
SELECT SINGLE * FROM enlfdir
WHERE funcname = tfdir-funcname.
SELECT SINGLE * FROM tadir
WHERE pgmid = 'R3TR'
AND object = 'FUGR'
AND obj_name = enlfdir-area.
MOVE : tadir-devclass TO v_devclass.
ENDIF.
ENDIF.
* Find SAP Modifactions
SELECT * FROM tadir
INTO TABLE jtab
WHERE pgmid = 'R3TR'
AND object = 'SMOD'
AND devclass = v_devclass.
SELECT SINGLE * FROM tstct
WHERE sprsl EQ sy-langu
AND tcode EQ p_tcode.
FORMAT COLOR COL_POSITIVE INTENSIFIED OFF.
WRITE:/(19) 'Transaction Code - ',
20(20) p_tcode,
45(50) tstct-ttext.
SKIP.
IF NOT jtab[] IS INITIAL.
WRITE:/(95) sy-uline.
FORMAT COLOR COL_HEADING INTENSIFIED ON.
WRITE:/1 sy-vline,
2 'Exit Name',
21 sy-vline ,
22 'Description',
95 sy-vline.
WRITE:/(95) sy-uline.
LOOP AT jtab.
SELECT SINGLE * FROM modsapt
WHERE sprsl = sy-langu AND
name = jtab-obj_name.
FORMAT COLOR COL_NORMAL INTENSIFIED OFF.
WRITE:/1 sy-vline,
2 jtab-obj_name HOTSPOT ON,
21 sy-vline ,
22 modsapt-modtext,
95 sy-vline.
ENDLOOP.
WRITE:/(95) sy-uline.
DESCRIBE TABLE jtab.
SKIP.
FORMAT COLOR COL_TOTAL INTENSIFIED ON.
WRITE:/ 'No of Exits:' , sy-tfill.
ELSE.
FORMAT COLOR COL_NEGATIVE INTENSIFIED ON.
WRITE:/(95) 'No User Exit exists'.
ENDIF.
ELSE.
FORMAT COLOR COL_NEGATIVE INTENSIFIED ON.
WRITE:/(95) 'Transaction Code Does Not Exist'.
ENDIF.
* Take the user to SMOD for the Exit that was selected.
AT LINE-SELECTION.
GET CURSOR FIELD field1.
CHECK field1(4) EQ 'JTAB'.
SET PARAMETER ID 'MON' FIELD sy-lisel+1(10).
CALL TRANSACTION 'SMOD' AND SKIP FIRST SCREEN.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/9437124/viewspace-915244/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux 怎麼根據程式號,找對應的程式Linux
- 根據api檔案生成程式碼API
- 根據使用者編號生成邀請碼
- OpenAPI Generator,根據Swagger/OpenAPI生成程式碼的工具APISwagger
- 根據使用者名稱和密碼查詢使用者密碼
- mybatis根據表逆向自動化生成程式碼MyBatis
- EF3.1 根據資料庫生成程式碼資料庫
- 根據使用者來獲取渠道
- 根據業務摸索出的一個selenium程式碼模版(python)Python
- 前後端分離-根據程式碼講解思路後端
- linux 下根據埠kill 程式Linux
- 根據使用者的不同登入不同的頁面
- ABAP 根據使用者名稱查姓名
- 商城-使用者註冊-根據使用者名稱和密碼查詢使用者密碼
- PHP利用反射根據類名反向尋找類所在檔案PHP反射
- 根據URL地址生成二維碼
- Python 根據id生成唯一碼Python
- js根據字尾判斷檔案檔案型別的程式碼JS型別
- 前端利器!讓AI根據手繪原型生成HTML | 教程+程式碼前端AI原型HTML
- 前端慌不慌?AI根據手繪原型生成HTML【附程式碼】前端AI原型HTML
- 【演算法】數學之旅,根據素數特徵尋找底數演算法特徵
- Laravel根據使用者id生成四位數唯一邀請碼Laravel
- mybatis入門程式:mybatis根據使用者名稱稱模糊查詢使用者資訊MyBatis
- 根據題庫設定刷題程式
- 根據軌跡分析出使用者家在哪
- Excel 中index和match函式 搭配使用 根據學號找對應的姓名ExcelIndex函式
- HUAWEI防火牆雙出口根據鏈路優先順序主備備份防火牆
- 機器學習根據文字生成圖片教程(附python程式碼)機器學習Python
- 如何查詢SAP的舊TCODE對應新的TCODE
- 根據年月日判斷星期幾的c程式C程式
- 根據提示操作
- target/mmk-ui-api: 根據規則引擎掃描惡意程式碼的工具UIAPI
- [程式碼結構設計]根據不同條件使用不同實現類的業務程式碼設計
- SAP RETAIL 如何根據分配表查到根據它建立的採購訂單?AI
- 最簡單的Qt程式:根據使用者所輸入圓半徑計算圓面積QT
- 在 NGINX 中根據使用者真實 IP 進行限制Nginx
- 根據使用者型別跳轉頁面(基於mybatis)型別MyBatis
- 根據除錯工具看Vue原始碼之watch除錯Vue原始碼
- Linux根據程式號,檢視相關資訊Linux