备忘录:ABAP 查找出口

[color=Purple]TABLES:tstc,
       tadir,
       modsapt,
       modact,
       trdir,
       tfdir,
       enlfdir,
       tstct.

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.
[/color]

[本日志由 春暖花开 于 2010-04-27 08:08 PM 编辑]
文章来自: 转贴
引用通告: 查看所有引用 | 我要引用此文章
Tags:
相关日志:
评论: 0 | 引用: 0 | 查看次数: 118
发表评论
昵 称:
密 码: 游客发言不需要密码.
内 容:
验证码: 验证码
选 项:
虽然发表评论不用注册,但是为了保护您的发言权,建议您注册帐号.
字数限制 1000 字 | UBB代码 开启 | [img]标签 关闭