बैश स्प्लिट स्ट्रिंग उदाहरण

Bash Split String Examples

हमें प्रोग्रामिंग में विभिन्न उद्देश्यों के लिए स्ट्रिंग डेटा को विभाजित करने की आवश्यकता है। कई प्रोग्रामिंग भाषाओं में किसी भी स्ट्रिंग डेटा को कई भागों में विभाजित करने के लिए 'स्प्लिट' नामक एक अंतर्निहित फ़ंक्शन होता है। लेकिन स्ट्रिंग को विभाजित करने के लिए बैश में कोई अंतर्निहित फ़ंक्शन नहीं है। आम तौर पर, किसी भी स्ट्रिंग डेटा को विभाजित करने के लिए सिंगल या एकाधिक डिलीमीटर का उपयोग किया जाता है। आप स्ट्रिंग को बैश में कैसे विभाजित कर सकते हैं, इस ट्यूटोरियल में विभिन्न उदाहरणों का उपयोग करके दिखाया गया है।








$IFS चर का उपयोग करना

एक स्ट्रिंग को शब्दों में विभाजित करने के लिए विशेष शेल चर $IFS का उपयोग बैश में किया जाता है। $IFS वैरिएबल को इंटरनल फील्ड सेपरेटर (IFS) कहा जाता है जिसका उपयोग स्ट्रिंग को विभाजित करने के लिए विशिष्ट सीमांकक को निर्दिष्ट करने के लिए किया जाता है। $IFS द्वारा बैश में शब्द सीमाओं की पहचान की जाती है। सफेद स्थान इस चर के लिए डिफ़ॉल्ट सीमांकक मान है। कोई अन्य मान जैसे ' ', ' ', '-' आदि। का उपयोग सीमांकक के रूप में किया जा सकता है। मान को $IFS चर में निर्दिष्ट करने के बाद, स्ट्रिंग मान को दो विकल्पों द्वारा पढ़ा जा सकता है। ये '-r' और '-a' हैं। विकल्प, '-r' का उपयोग बैकस्लैश () को एस्केप कैरेक्टर के बजाय एक कैरेक्टर के रूप में पढ़ने के लिए किया जाता है और '-ए' विकल्प का उपयोग स्प्लिट-टेड शब्दों को एक ऐरे वेरिएबल में स्टोर करने के लिए किया जाता है। बैश में $IFS चर का उपयोग किए बिना स्ट्रिंग को विभाजित-टेड किया जा सकता है। स्ट्रिंग डेटा को विभाजित करने के विभिन्न तरीके ($IFS के साथ या $IFS के बिना) निम्नलिखित उदाहरणों में दिखाए गए हैं।



उदाहरण -1: स्प्लिट स्ट्रिंग के आधार पर

स्ट्रिंग मान को डिफ़ॉल्ट रूप से सफेद स्थान से विभाजित किया जाता है। 'Split1.sh' नाम की एक फाइल बनाएं और निम्न कोड जोड़ें। यहां, स्ट्रिंग मान निर्दिष्ट करने के लिए $text चर का उपयोग किया जाता है। शेल चर, $IFS का उपयोग उस वर्ण को निर्दिष्ट करने के लिए किया जाता है जिसका उपयोग स्ट्रिंग डेटा को विभाजित करने के लिए किया जाएगा। इस लिपि में सेपरेटर के रूप में स्पेस का प्रयोग किया गया है। स्प्लिट-टेड डेटा को $strarr नामक एक सरणी चर में संग्रहीत करने के लिए रीडिंग कमांड के साथ '-a' विकल्प का उपयोग किया जाता है। सरणी के प्रत्येक तत्व को पढ़ने के लिए 'फॉर' लूप का उपयोग किया जाता है, $strarr।



split1.sh





#!/बिन/बैश

#स्ट्रिंग मान को परिभाषित करें
मूलपाठ='लिनक्सहिंट में आपका स्वागत है'

# स्थान को सीमांकक के रूप में सेट करें
भारतीय विदेश सेवा=''

#स्पेस डिलीमीटर के आधार पर विभाजित शब्दों को एक सरणी में पढ़ें
पढ़ना -प्रतिस्ट्रार<<< '$पाठ'

#कुल शब्दों की गणना करें
फेंक दिया 'वहां${#स्ट्रार[*]}पाठ में शब्द।'

# लूप का उपयोग करके सरणी के प्रत्येक मान को प्रिंट करें
के लियेबजेमें '${स्ट्रार[@]}';
करना
printf '$ घंटेएन'
किया हुआ

आउटपुट:

स्क्रिप्ट चलाएँ।



$दे घुमा केsplit1.sh

स्क्रिप्ट चलाने के बाद निम्न आउटपुट दिखाई देगा।

उदाहरण -2: किसी विशेष वर्ण के आधार पर विभाजित स्ट्रिंग

स्ट्रिंग मान को विभाजित करने के लिए किसी विशिष्ट वर्ण को विभाजक के रूप में उपयोग किया जा सकता है। नाम की एक फाइल बनाएं split2.sh और निम्नलिखित कोड जोड़ें। यहां, इनपुट स्ट्रिंग के रूप में अल्पविराम (,) जोड़कर पुस्तक का नाम, लेखक का नाम और मूल्य मूल्य लिया जाता है। इसके बाद, स्ट्रिंग मान को विभाजित-टेड किया जाता है और शेल चर, $IFS के मान के आधार पर एक सरणी में संग्रहीत किया जाता है। सरणी तत्वों का प्रत्येक मान अनुक्रमणिका मान द्वारा मुद्रित किया जाता है।

split2.sh

#!/बिन/बैश

#स्ट्रिंग मान पढ़ें
फेंक दिया 'अल्पविराम को अलग करके पुस्तक का नाम, लेखक का नाम और मूल्य दर्ज करें। '
पढ़नामूलपाठ

# अल्पविराम को सीमांकक के रूप में सेट करें
भारतीय विदेश सेवा=','

#विभाजित शब्दों को अल्पविराम सीमांकक के आधार पर एक सरणी में पढ़ें
पढ़ना -प्रतिस्ट्रार<<< '$पाठ'

#विभाजित शब्दों को प्रिंट करें
फेंक दिया 'पुस्तक का नाम:${स्ट्रार[0] }'
फेंक दिया 'लेखक का नाम :${स्ट्रार[1]}'
फेंक दिया 'कीमत :${स्ट्रार[2]}'

आउटपुट:

स्क्रिप्ट चलाएँ।

$दे घुमा केsplit2.sh

स्क्रिप्ट चलाने के बाद निम्न आउटपुट दिखाई देगा।

उदाहरण -3: $IFS चर के बिना स्ट्रिंग को विभाजित करें

यह उदाहरण दिखाता है कि कैसे स्ट्रिंग मान को बैश में $IFS का उपयोग किए बिना विभाजित किया जा सकता है। नाम की एक फाइल बनाएं ' स्प्लिट3.श ' और निम्नलिखित कोड जोड़ें। लिपि के अनुसार, कोलन के साथ एक टेक्स्ट मान (:) बंटवारे के लिए इनपुट के रूप में लेना पड़ता है। यहां, स्ट्रिंग डेटा को विभाजित करने के लिए -d विकल्प के साथ 'readarray' कमांड का उपयोग किया जाता है। $IFS जैसे कमांड में सेपरेटर कैरेक्टर को परिभाषित करने के लिए '-d' विकल्प का उपयोग किया जाता है। अगला, 'फॉर' लूप का उपयोग सरणी तत्वों को प्रिंट करने के लिए किया जाता है।

split3.sh

#!/बिन/बैश

#मुख्य स्ट्रिंग पढ़ें
फेंक दिया 'विभाजित करने के लिए कोलन (:) के साथ स्ट्रिंग दर्ज करें'
पढ़नामेनस्ट्रो

# सीमांकक के आधार पर स्ट्रिंग को विभाजित करें, ':'
रीडअरे-डी:-टीस्ट्रार<<< '$mainstr'
printf 'एन'

# लूप का उपयोग करके सरणी के प्रत्येक मान को प्रिंट करें
के लिये (( एन=0; एन< ${#स्ट्रार[*]}; एन++))
करना
फेंक दिया '${स्ट्रार [एन]}'
किया हुआ

आउटपुट:

स्क्रिप्ट चलाएँ।

$दे घुमा केsplit3.sh

स्क्रिप्ट चलाने के बाद निम्न आउटपुट दिखाई देगा।

उदाहरण -4: स्ट्रिंग को बहु-वर्ण सीमांकक से विभाजित करें

पिछले सभी उदाहरणों में स्ट्रिंग मान को एकल वर्ण सीमांकक द्वारा विभाजित किया गया है। मल्टी-कैरेक्टर डिलीमीटर का उपयोग करके आप स्ट्रिंग को कैसे विभाजित कर सकते हैं इस उदाहरण में दिखाया गया है। नाम की एक फाइल बनाएं टाइम्स स्प्लिट4.शो और निम्नलिखित कोड जोड़ें। यहां, स्ट्रिंग डेटा को स्टोर करने के लिए $text वेरिएबल का उपयोग किया जाता है। $delimiter चर का उपयोग एक बहु-वर्ण डेटा निर्दिष्ट करने के लिए किया जाता है जिसे अगले कथनों में सीमांकक के रूप में उपयोग किया जाता है। $myarray चर का उपयोग प्रत्येक स्प्लिट-टेड डेटा को एक सरणी तत्व के रूप में संग्रहीत करने के लिए किया जाता है। अंत में, सभी स्प्लिट-टेड डेटा 'फॉर' लूप का उपयोग करके मुद्रित किए जाते हैं।

split4.sh

#!/बिन/बैश

#स्ट्रिंग को विभाजित करने के लिए परिभाषित करें
मूलपाठ='सीखेंHTMLसीखेंPHPlearnMySQLसीखेंजावास्क्रिप्ट'

#बहु-वर्ण सीमांकक परिभाषित करें
सीमांकक='सीखना'
#सीमांकक को मुख्य स्ट्रिंग से जोड़ें
डोरी=$पाठ$सीमांकक

#पाठ को सीमांकक के आधार पर विभाजित करें
मायएरे=()
जबकि [[ $स्ट्रिंग ]];करना
मायएरे+=( '${string%%'$delimiter'*}' )
डोरी=${स्ट्रिंग#*'$ सीमांकक'}
किया हुआ

#विभाजन के बाद शब्दों को प्रिंट करें
के लियेमूल्यमें ${मायअरे[@]}
करना
फेंक दिया -एन '$मूल्य'
किया हुआ
printf 'एन'

आउटपुट:

स्क्रिप्ट चलाएँ।

$दे घुमा केsplit4.sh

स्क्रिप्ट चलाने के बाद निम्न आउटपुट दिखाई देगा।

निष्कर्ष:

विभिन्न प्रोग्रामिंग उद्देश्यों के लिए स्ट्रिंग डेटा को विभाजित करने की आवश्यकता है। इस ट्यूटोरियल में बैश में स्ट्रिंग डेटा को विभाजित करने के विभिन्न तरीके दिखाए गए हैं। आशा है, उपरोक्त उदाहरणों का अभ्यास करने के बाद, पाठक अपनी आवश्यकता के आधार पर किसी भी स्ट्रिंग डेटा को विभाजित करने में सक्षम होंगे।

अधिक जानकारी के लिए देखें वीडियो !