SAP ABAP - स्ट्रिंग्स

Strings, जो एबीएपी प्रोग्रामिंग में व्यापक रूप से उपयोग किए जाते हैं, पात्रों का एक क्रम है।

हम अल्फ़ान्यूमेरिक वर्ण रखने के लिए डेटा प्रकार C चर का उपयोग करते हैं, जिसमें न्यूनतम 1 वर्ण और अधिकतम 65,535 वर्ण होते हैं। डिफ़ॉल्ट रूप से, ये बाईं ओर संरेखित होते हैं।

स्ट्रिंग्स बनाना

निम्नलिखित घोषणा और आरंभिक शब्द 'हैलो' शब्द से मिलकर एक स्ट्रिंग बनाता है। स्ट्रिंग का आकार 'हैलो' शब्द में वर्णों की संख्या है।

Data my_Char(5) VALUE 'Hello'.

निम्नलिखित कार्यक्रम तार बनाने का एक उदाहरण है।

REPORT YT_SEP_15. 
DATA my_Char(5) VALUE 'Hello'. 
Write my_Char.

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

Hello

स्ट्रिंग लंबाई

चरित्र तार की लंबाई का पता लगाने के लिए, हम उपयोग कर सकते हैं STRLEN statement। STRLEN () फ़ंक्शन स्ट्रिंग में निहित वर्णों की संख्या लौटाता है।

उदाहरण

REPORT YT_SEP_15. 
DATA: title_1(10) VALUE 'Tutorials',
      length_1 TYPE I. 
	
length_1 = STRLEN( title_1 ). 
Write: / 'The Length of the Title is:', length_1.

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

The Length of the Title is: 9

ABAP स्टेटमेंट की एक विस्तृत श्रृंखला का समर्थन करता है जो स्ट्रिंग्स में हेरफेर करता है।

क्र.सं. कथन और उद्देश्य
1

CONCATENATE

तीसरा तार बनाने के लिए दो तार जुड़े हुए हैं।

2

CONDENSE

यह कथन अंतरिक्ष वर्णों को हटा देता है।

3

STRLEN

एक खेत की लंबाई का पता लगाने के लिए उपयोग किया जाता है।

4

REPLACE

पात्रों में प्रतिस्थापन करने के लिए उपयोग किया जाता है।

5

SEARCH

चरित्र तार में खोजों को चलाने के लिए।

6

SHIFT

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

7

SPLIT

किसी फ़ील्ड की सामग्री को दो या अधिक फ़ील्ड में विभाजित करने के लिए उपयोग किया जाता है।

निम्नलिखित उदाहरण उपर्युक्त कथनों में से कुछ का उपयोग करता है -

उदाहरण

REPORT YT_SEP_15. 
DATA: title_1(10) VALUE 'Tutorials', 
      title_2(10) VALUE 'Point',
      spaced_title(30) VALUE 'Tutorials  Point  Limited',
      sep,
      dest1(30),
      dest2(30).
	
CONCATENATE title_1 title_2 INTO dest1. 
Write: / 'Concatenation:', dest1. 

CONCATENATE title_1 title_2 INTO dest2 SEPARATED BY sep. 
Write: / 'Concatenation with Space:', dest2. 

CONDENSE spaced_title.
Write: / 'Condense with Gaps:', spaced_title. 

CONDENSE spaced_title NO-GAPS. 
Write: / 'Condense with No Gaps:', spaced_title.

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

Concatenation: TutorialsPoint 
Concatenation with Space: Tutorials Point 
Condense with Gaps: Tutorials Point Limited 
Condense with No Gaps: TutorialsPointLimited

Note -

  • कॉनकैटैशन के मामले में, 'सेप' खेतों के बीच में एक जगह डालता है।

  • CONDENSE कथन फ़ील्ड के बीच रिक्त स्थान को हटाता है, लेकिन केवल 1 वर्ण का स्थान छोड़ता है।

  • 'NO-GAPS' CONDENSE कथन का एक वैकल्पिक जोड़ है जो सभी रिक्त स्थान को हटा देता है।