SAP 尋找使用者出口Exit

mmccking發表於2011-12-20
如何查詢事務程式碼所在程式的使用者出口(user-exit)[@more@]

方法一:
1。 執行tcode --&gt system --&gt status,找出程式名稱。
2。SE80;輸入第一步中找到的程式名稱。用選單:GOTO --&gt Attributes,找出Package 名稱。(注:也可以用SE93,查這個程式所在的Package)
3。 SE80 --&gt Repository Information System --&gt Enhancements --&gt Customer Exits --&gt Enhancements --&gt將第二步中找到的Package 名稱輸入,執行,就可以找到tcode的所有使用者出口。

————————————————————


方法二:
編寫ABAP程式,程式碼如下:
===========================================================
作者: qiujun(http://qiujun.itpub.net) 謝謝作者
發表於:2007.10.23 17:01
分類: ABAP
出處:http://qiujun.itpub.net/post/24006/407469
---------------------------------------------------------------
TABLES : tstc, "SAP Transaction Codes(SAP 事務程式碼)
tadir, "Directory of Repository Objects(資源庫物件的目錄)
modsapt, "SAP Enhancements - Short Texts(SAP增強-短檔案)
modact, "Modifications(修正)
trdir, "System table TRDIR(系統表 TRDIR)
tfdir, "Function Module(功能模組)
enlfdir, "Additional Attributes for Function Modules(功能模組的附加屬性)
tstct. "Transaction Code Texts(事務程式碼文字)

DATA : jtab LIKE tadir OCCURS 0 WITH HEADER LINE.
DATA : field1(30).
DATA : v_devclass LIKE tadir-devclass.

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.


START-OF-SELECTION.
SELECT SINGLE * FROM tstc WHERE tcode EQ p_tcode.
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.

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:/(12) '事務程式碼 - ',
13(20) p_tcode,
34(10) '功能 - ' ,
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:/ '使用者出口數量:' , sy-tfill.
ELSE.
FORMAT COLOR COL_NEGATIVE INTENSIFIED ON.
WRITE:/(95) '此TCode沒有使用者出口!'.
ENDIF.
ELSE.
FORMAT COLOR COL_NEGATIVE INTENSIFIED ON.
WRITE:/(95) '事務程式碼不存在!'.
ENDIF.

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/8356764/viewspace-1056901/,如需轉載,請註明出處,否則將追究法律責任。

相關文章