SAP ABAP - उपयोगकर्ता निकास

यदि उपयोगकर्ता SAP एक्सट्रैक्टर मानक डेटा या आवश्यक कार्यक्षमता प्रदान नहीं करते हैं, उदाहरण के लिए प्राधिकरण या समय जाँच में, तो उपयोगकर्ता निकासी का उपयोग निष्कर्षण में किया जाता है। उपयोगकर्ता निकास आमतौर पर बिक्री और वितरण (एसडी) मॉड्यूल में उपयोग किया जाता है। बिक्री, परिवहन, शिपिंग और बिलिंग के क्षेत्रों में एसएपी द्वारा प्रदान किए गए कई निकास हैं। एक उपयोगकर्ता निकास को कुछ बदलाव करने के लिए डिज़ाइन किया गया है जब मानक एसएपी सभी आवश्यकताओं को पूरा करने में सक्षम नहीं है।

बिक्री के प्रत्येक क्षेत्र में कौन से निकास उपलब्ध हैं, इसका उपयोग करने में सक्षम होने के लिए, इस रास्ते का उपयोग करके IMG पर जाएं: IMG → बिक्री और वितरण → सिस्टम संशोधन → उपयोगकर्ता निकास। एसडी के क्षेत्रों में प्रत्येक निकास के लिए प्रलेखन को अच्छी तरह से समझाया गया है।

उदाहरण के लिए, यदि आप बिक्री दस्तावेज़ प्रसंस्करण (अनुबंध, उद्धरण या बिक्री आदेश) में उपयोगकर्ता से बाहर निकलना चाहते हैं, तो ऊपर बताए गए मार्ग का अनुसरण करें और नोड का विस्तार करना जारी रखें उपयोगकर्ता निकास बिक्री में → उपयोगकर्ता निकास। बिक्री दस्तावेज़ प्रसंस्करण में उपलब्ध सभी उपयोगकर्ता निकास को देखने के लिए आइकन दस्तावेज़ पर क्लिक करें।

क्र.सं. उपयोगकर्ता से बाहर निकलें और विवरण
1

USEREXIT_FIELD_MODIFICATION

स्क्रीन विशेषताओं को संशोधित करने के लिए उपयोग किया जाता है।

2

USEREXIT_SAVE_DOCUMENT

जब उपयोगकर्ता हिट को बचाने के संचालन में मदद करता है।

3

USEREXIT_SAVE_DOCUMENT_PREPARE

इनपुट क्षेत्रों की जांच करने के लिए बहुत उपयोगी है, क्षेत्र में कोई भी मूल्य डालें या उपयोगकर्ताओं को पॉपअप दिखाएं और दस्तावेज़ की पुष्टि करें।

4

USEREXIT_MOVE_FIELD_TO_VBAK

उपयोग जब उपयोगकर्ता हेडर परिवर्तन हेडर कार्य क्षेत्र में ले जाया जाता है।

5

USEREXIT_MOVE_FIELD_TO_VBAP

उपयोग किया जाता है जब उपयोगकर्ता आइटम परिवर्तन SAP आइटम कार्य क्षेत्र में ले जाए जाते हैं।

उपयोगकर्ता निकास ग्राहक निकास के रूप में एक ही उद्देश्य प्रदान करता है लेकिन वे केवल एसडी मॉड्यूल के लिए उपलब्ध हैं। एग्जिट फंक्शन मॉड्यूल को कॉल के रूप में लागू किया जाता है। उपयोगकर्ता निकास SAP मानक कार्यक्रमों में संशोधन कर रहे हैं।

उदाहरण

REPORT ZUSEREXIT1. 
TABLES:   
   TSTC, TSTCT,
   TADIR, TRDIR, TFDIR, ENLFDIR,
   MODSAPT, MODACT. 
	
DATA:   
   JTAB LIKE TADIR OCCURS 0 WITH HEADER LINE,
   field1(30),
   v_devclass LIKE TADIR-devclass. 
	
PARAMETERS:
   P_TCODE LIKE TSTC-tcode OBLIGATORY. 
	
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 EQ 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:/(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) 'User Exit doesn’t exist'.
   ENDIF. 
ELSE.

   FORMAT COLOR COL_NEGATIVE INTENSIFIED ON.
   WRITE:/(95) 'Transaction Code Does Not Exist'. 
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.

प्रसंस्करण करते समय, लेनदेन कोड 'ME01' दर्ज करें और F8 (निष्पादित करें) बटन दबाएं। उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -