50 `लेकिन` कमांड उदाहरण

50 Sed Command Examples



`sed` GNU/Linux की एक उपयोगी टेक्स्ट प्रोसेसिंग सुविधा है। Sed का फुल फॉर्म स्ट्रीम एडिटर होता है। `sed` कमांड का उपयोग करके कई प्रकार के सरल और जटिल टेक्स्ट प्रोसेसिंग कार्य बहुत आसानी से किए जा सकते हैं। टेक्स्ट या फ़ाइल में किसी विशेष स्ट्रिंग को `sed कमांड के साथ रेगुलर एक्सप्रेशन का उपयोग करके खोजा, बदला और हटाया जा सकता है। लेकिन यह आदेश अस्थायी रूप से सभी प्रकार के संशोधन करता है और मूल फ़ाइल सामग्री डिफ़ॉल्ट रूप से नहीं बदली जाती है। यदि आवश्यक हो तो उपयोगकर्ता संशोधित सामग्री को किसी अन्य फ़ाइल में संग्रहीत कर सकता है। इस ट्यूटोरियल में `sed` कमांड के मूल उपयोगों को ५० अद्वितीय उदाहरणों का उपयोग करके समझाया गया है। इस ट्यूटोरियल को शुरू करने से पहले आपको निम्न कमांड को चलाकर अपने ऑपरेटिंग सिस्टम में `sed` के स्थापित संस्करण की जांच करनी चाहिए। ट्यूटोरियल GNU sed पर आधारित है। तो इस ट्यूटोरियल में दिखाए गए उदाहरणों का अभ्यास करने के लिए `sed` के इस संस्करण की आवश्यकता होगी।

$एसईडी --संस्करण

निम्न आउटपुट दिखाता है कि सिस्टम में संस्करण 4.4 का GNU Sed स्थापित है।









वाक्य - विन्यास:



एसईडी [विकल्प]...[लिपि] [फ़ाइल]

यदि `sed` कमांड के साथ कोई फ़ाइल नाम प्रदान नहीं किया गया है, तो स्क्रिप्ट मानक इनपुट डेटा पर काम करेगी। `Sed` स्क्रिप्ट को बिना किसी विकल्प के निष्पादित किया जा सकता है।





विषय :

  1. 'Sed' का उपयोग करके मूल पाठ प्रतिस्थापन
  2. 'g' विकल्प का उपयोग करके किसी फ़ाइल की किसी विशेष पंक्ति में टेक्स्ट के सभी उदाहरणों को बदलें
  3. प्रत्येक पंक्ति पर केवल एक मैच की दूसरी घटना को बदलें
  4. प्रत्येक पंक्ति पर केवल एक मैच की अंतिम घटना को बदलें
  5. फ़ाइल में पहले मिलान को नए टेक्स्ट से बदलें
  6. फ़ाइल में अंतिम मिलान को नए टेक्स्ट से बदलें
  7. फ़ाइल पथों की खोज और प्रतिस्थापन को प्रबंधित करने के लिए प्रतिस्थापन आदेशों में बैकस्लैश से बचना
  8. सभी फ़ाइलों को पूर्ण पथ से बदलें, केवल फ़ाइल नाम कोई निर्देशिका नहीं
  9. टेक्स्ट को प्रतिस्थापित करें लेकिन केवल तभी जब स्ट्रिंग में कोई अन्य टेक्स्ट मिल जाए
  10. टेक्स्ट को प्रतिस्थापित करें लेकिन केवल तभी जब स्ट्रिंग में कोई अन्य टेक्स्ट न मिले
  11. ' का उपयोग करके मिलान पैटर्न के बाद पहले स्ट्रिंग जोड़ें 1 '
  12. मेल खाने वाली लाइनें हटाएं
  13. मैचिंग लाइन और 2 लाइन मैचिंग लाइन के बाद डिलीट करें
  14. पाठ की पंक्ति के अंत में सभी रिक्त स्थान हटाएं
  15. उन सभी पंक्तियों को हटा दें जिनका पंक्ति पर दो बार मिलान होता है
  16. उन सभी पंक्तियों को हटा दें जिनमें केवल खाली स्थान है
  17. सभी गैर-मुद्रण योग्य वर्ण हटाएं
  18. अगर लाइन में कोई मैच है तो लाइन के अंत में कुछ जोड़ें
  19. यदि मैच से पहले लाइन इंसर्ट लाइन में कोई मेल है
  20. यदि मैच के बाद लाइन इंसर्ट लाइन में कोई मेल है
  21. यदि कोई मिलान नहीं है तो पंक्ति के अंत में कुछ जोड़ें
  22. यदि कोई मेल नहीं है तो लाइन को हटा दें
  23. पाठ के बाद स्थान जोड़ने के बाद मिलान किए गए पाठ को डुप्लिकेट करें
  24. स्ट्रिंग्स की सूची में से किसी एक को नई स्ट्रिंग से बदलें
  25. एक मिलान वाली स्ट्रिंग को उस स्ट्रिंग से बदलें जिसमें नई लाइनें हों
  26. फ़ाइल से नई पंक्तियाँ निकालें और प्रत्येक पंक्ति के अंत में अल्पविराम डालें
  27. पाठ को कई पंक्तियों में विभाजित करने के लिए अल्पविराम निकालें और नई पंक्तियाँ जोड़ें
  28. केस असंवेदनशील मिलान ढूंढें और लाइन हटाएं
  29. केस असंवेदनशील मिलान ढूंढें और नए टेक्स्ट से बदलें
  30. केस असंवेदनशील मिलान ढूंढें और एक ही टेक्स्ट के सभी अपरकेस से बदलें
  31. केस असंवेदनशील मिलान ढूंढें और एक ही टेक्स्ट के सभी लोअरकेस से बदलें
  32. टेक्स्ट में सभी अपरकेस वर्णों को लोअरकेस वर्णों से बदलें
  33. लाइन में नंबर खोजें और नंबर के बाद करेंसी सिंबल लगाएं
  34. उन संख्याओं में अल्पविराम जोड़ें जिनमें 3 से अधिक अंक हों
  35. टैब वर्णों को 4 स्पेस वर्णों से बदलें
  36. 4 लगातार स्पेस कैरेक्टर को टैब कैरेक्टर से बदलें
  37. सभी पंक्तियों को पहले ८० वर्णों में काटें
  38. एक स्ट्रिंग रेगेक्स खोजें और उसके बाद कुछ मानक टेक्स्ट जोड़ें
  39. एक स्ट्रिंग रेगेक्स और उसके बाद मिली स्ट्रिंग की दूसरी प्रति खोजें
  40. फ़ाइल से बहु-पंक्ति `sed` स्क्रिप्ट चलाना
  41. एक बहु-पंक्ति पैटर्न का मिलान करें और नए बहु-पंक्ति पाठ के साथ बदलें
  42. पैटर्न से मेल खाने वाले दो शब्दों का क्रम बदलें
  43. कमांड-लाइन से कई sed कमांड का उपयोग करें
  44. अन्य कमांड के साथ sed को मिलाएं
  45. फ़ाइल में एक खाली लाइन डालें
  46. फ़ाइल की प्रत्येक पंक्ति से सभी अल्फा-न्यूमेरिक वर्ण हटाएं।
  47. स्ट्रिंग से मिलान करने के लिए '&' का प्रयोग करें
  48. शब्दों की जोड़ी बदलें
  49. प्रत्येक शब्द के पहले अक्षर को बड़ा करें
  50. फ़ाइल के लाइन नंबर प्रिंट करें

1. 'sed' का उपयोग करके मूल पाठ प्रतिस्थापन

पाठ के किसी विशेष भाग को `sed` कमांड का उपयोग करके खोज और प्रतिस्थापन पैटर्न का उपयोग करके खोजा और बदला जा सकता है। निम्नलिखित उदाहरण में, 's' खोज और प्रतिस्थापन कार्य को इंगित करता है। 'बैश' शब्द टेक्स्ट, बैश स्क्रिप्टिंग लैंग्वेज में खोजा जाएगा और यदि शब्द टेक्स्ट में मौजूद है तो इसे 'पर्ल' शब्द से बदल दिया जाएगा।



$फेंक दिया 'बैश स्क्रिप्टिंग लैंग्वेज' | एसईडी 'एस/बैश/पर्ल/'

आउटपुट:

पाठ में 'बैश' शब्द मौजूद है। तो आउटपुट 'पर्ल स्क्रिप्टिंग लैंग्वेज' है।

फ़ाइल सामग्री के किसी भी भाग को बदलने के लिए भी `sed` कमांड का उपयोग किया जा सकता है। नाम की एक टेक्स्ट फ़ाइल बनाएँ कार्यदिवस.txt निम्नलिखित सामग्री के साथ।

कार्यदिवस.txt

सोमवार
मंगलवार
बुधवार
गुरूवार
शुक्रवार
शनिवार
रविवार का दिन

निम्न आदेश 'रविवार' पाठ को खोजेगा और 'रविवार छुट्टी है' पाठ द्वारा प्रतिस्थापित करेगा।

$बिल्लीकार्यदिवस.txt
$एसईडी 's/रविवार/रविवार को छुट्टी है/'कार्यदिवस.txt

आउटपुट:

'रविवार' सप्ताहांत.txt फ़ाइल में मौजूद है और इस शब्द को उपरोक्त `sed` कमांड को निष्पादित करने के बाद टेक्स्ट द्वारा प्रतिस्थापित किया जाता है, 'रविवार छुट्टी है'।

ऊपर जाएँ

2. 'g' विकल्प का उपयोग करके किसी फ़ाइल की किसी विशेष पंक्ति में टेक्स्ट के सभी उदाहरणों को बदलें

मिलान पैटर्न की सभी घटनाओं को बदलने के लिए `sed` कमांड में 'g' विकल्प का उपयोग किया जाता है। नाम की एक टेक्स्ट फ़ाइल बनाएँ अजगर.txt निम्नलिखित सामग्री के साथ 'g' विकल्प के उपयोग को जानने के लिए। इस फ़ाइल में शब्द है। 'पायथन' कई बार।

अजगर.txt

पायथन एक बहुत ही लोकप्रिय भाषा है।
पायथन का उपयोग करना आसान है। पायथन सीखना आसान है।
पायथन एक क्रॉस-प्लेटफ़ॉर्म भाषा है

निम्न आदेश 'की सभी घटनाओं को प्रतिस्थापित करेगा अजगर ' फ़ाइल की दूसरी पंक्ति में, अजगर.txt . यहां, 'पायथन' दूसरी पंक्ति में दो बार होता है।

$ बिल्ली अजगर।टेक्स्ट
$ सेड'2 एस/पायथन/पर्ल/जी'अजगर।टेक्स्ट

आउटपुट:

स्क्रिप्ट चलाने के बाद निम्न आउटपुट दिखाई देगा। यहां, दूसरी पंक्ति में 'पायथन' की सभी घटनाओं को 'पर्ल' से बदल दिया जाता है।

ऊपर जाएँ

3. प्रत्येक पंक्ति पर केवल एक मैच की दूसरी घटना को बदलें

यदि कोई शब्द किसी फ़ाइल में कई बार प्रकट होता है तो प्रत्येक पंक्ति में शब्द की विशेष आवृत्ति को `sed` कमांड का उपयोग करके घटना संख्या के साथ प्रतिस्थापित किया जा सकता है। निम्न `sed` कमांड फ़ाइल की प्रत्येक पंक्ति में खोज पैटर्न की दूसरी घटना को प्रतिस्थापित करेगा, अजगर.txt .

$ सेड'एस/पायथन/पर्ल/जी2'अजगर।टेक्स्ट

आउटपुट:

उपरोक्त आदेश को चलाने के बाद निम्न आउटपुट दिखाई देगा। यहाँ, खोज पाठ, ' अजगर केवल दूसरी पंक्ति में दो बार प्रकट होता है और इसे टेक्स्ट से बदल दिया जाता है, ' पर्ल '।

ऊपर जाएँ

4. प्रत्येक पंक्ति पर केवल एक मैच की अंतिम घटना को बदलें

नाम की एक टेक्स्ट फ़ाइल बनाएँ lang.txt निम्नलिखित सामग्री के साथ।

lang.txt

बैश प्रोग्रामिंग भाषा। पायथन प्रोग्रामिंग भाषा। पर्ल प्रोग्रामिंग भाषा।
हाइपर टेक्स्ट मार्कअप लैंग्वेज।
एक्सटेंसिबल मार्कअप लैंग्वेज।

$एसईडी 'एस/(.*)प्रोग्रामिंग/1स्क्रिप्टिंग/'lang.txt

ऊपर जाएँ

5. फ़ाइल में पहले मिलान को नए टेक्स्ट से बदलें

निम्न आदेश खोज पैटर्न के केवल पहले मैच को प्रतिस्थापित करेगा, ' अजगर 'पाठ से, 'पर्ली' '। यहां, '1' पैटर्न की पहली घटना से मेल खाने के लिए प्रयोग किया जाता है।

$ बिल्ली अजगर।टेक्स्ट
$ सेड'1 एस / पायथन / पर्ल /'अजगर।टेक्स्ट

आउटपुट:

उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। यहां। पहली पंक्ति में 'पायथन' की पहली घटना को 'पर्ल' से बदल दिया जाता है।

ऊपर जाएँ

6. फ़ाइल में अंतिम मिलान को नए टेक्स्ट से बदलें

निम्न आदेश खोज पैटर्न की अंतिम घटना को प्रतिस्थापित करेगा, 'पायथन' 'पाठ से, 'दे घुमा के'। यहां, '$' प्रतीक का उपयोग पैटर्न की अंतिम घटना से मेल खाने के लिए किया जाता है।

$ बिल्ली अजगर।टेक्स्ट
$ लेकिन -ई'$ एस / पायथन / बैश /'अजगर।टेक्स्ट

आउटपुट:

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

ऊपर जाएँ

7. फ़ाइल पथों की खोज और प्रतिस्थापन को प्रबंधित करने के लिए प्रतिस्थापन आदेशों में बैकस्लैश से बचना

खोज और बदलने के लिए फ़ाइल पथ में बैकस्लैश से बचना आवश्यक है। `Sed` का निम्न आदेश फ़ाइल पथ में बैकस्लैश () जोड़ देगा।

$फेंक दिया /घर/उबंटू/कोड/पर्ल/जोड़ें.pl| एसईडी 'एस; /; \ /; जी'

आउटपुट:

फ़ाइल पथ, '/home/ubuntu/code/perl/add.pl' `sed` कमांड में इनपुट के रूप में प्रदान किया जाता है और उपरोक्त कमांड चलाने के बाद निम्न आउटपुट दिखाई देगा।

ऊपर जाएँ

8. सभी फ़ाइलों को पूर्ण पथ से बदलें, केवल फ़ाइल नाम कोई निर्देशिका नहीं

फ़ाइल नाम को फ़ाइल पथ से ` . का उपयोग करके बहुत आसानी से पुनर्प्राप्त किया जा सकता है बेसनाम ` आदेश। फ़ाइल पथ से फ़ाइल नाम पुनर्प्राप्त करने के लिए `sed` कमांड का भी उपयोग किया जा सकता है। निम्न आदेश फ़ाइल नाम को केवल `इको` कमांड द्वारा प्रदान किए गए फ़ाइल पथ से पुनर्प्राप्त करेगा।

$फेंक दिया '/home/ubuntu/temp/myfile.txt' | एसईडी 'एस/।*///'

आउटपुट:

उपरोक्त आदेश को चलाने के बाद निम्न आउटपुट दिखाई देगा। यहाँ, फ़ाइल नाम, ' myfile.txt' आउटपुट के रूप में मुद्रित किया जाता है।

ऊपर जाएँ

9. टेक्स्ट को प्रतिस्थापित करें लेकिन केवल तभी जब स्ट्रिंग में कोई अन्य टेक्स्ट मिल जाए

नाम की एक फाइल बनाएं ' विभाग टेक्स्ट' अन्य पाठ के आधार पर किसी भी पाठ को बदलने के लिए निम्नलिखित सामग्री के साथ।

विभाग

कुल छात्रों की सूची:

सीएसई - गणना
ईईई - काउंट
सिविल - काउंट

निम्नलिखित `sed` कमांड में दो रिप्लेस कमांड का उपयोग किया जाता है। यहाँ, पाठ, ' गिनती 'द्वारा प्रतिस्थापित किया जाएगा 100 उस पंक्ति में जिसमें पाठ है, 'सीएसई' 'और पाठ,' गिनती' द्वारा प्रतिस्थापित किया जाएगा 70 उस पंक्ति में जिसमें खोज पैटर्न है, ' ईईई' .

$बिल्लीविभाग
$एसईडी -और '/सीएसई/एस/गणना/100/; /ईईई/एस/गणना/70/;'विभाग

आउटपुट:

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

ऊपर जाएँ

10. टेक्स्ट को प्रतिस्थापित करें लेकिन केवल अगर स्ट्रिंग में कोई अन्य टेक्स्ट नहीं मिलता है

निम्नलिखित `sed` कमांड उस पंक्ति में 'गणना' मान को प्रतिस्थापित करेगा जिसमें टेक्स्ट, 'सीएसई' शामिल नहीं है। विभाग फ़ाइल में दो पंक्तियाँ हैं जिनमें 'CSE' टेक्स्ट नहीं है। ऐसा ' गिनती ' टेक्स्ट को दो पंक्तियों में 80 से बदल दिया जाएगा।

$बिल्लीविभाग
$एसईडी -मैं -और '/सीएसई/! एस/गिनती/80/;'विभाग

आउटपुट:

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

ऊपर जाएँ

11. मिलान पैटर्न के पहले और बाद में '1' का उपयोग करके स्ट्रिंग जोड़ें

`sed` कमांड के मिलान पैटर्न के क्रम को '1', '2' इत्यादि द्वारा दर्शाया जाता है। निम्नलिखित `sed` कमांड पैटर्न, 'बैश' की खोज करेगा और यदि पैटर्न मेल खाता है तो इसे टेक्स्ट को बदलने के हिस्से में '1' द्वारा एक्सेस किया जाएगा। यहां, टेक्स्ट, 'बैश' को इनपुट टेक्स्ट में खोजा जाता है और, एक टेक्स्ट पहले जोड़ा जाता है और दूसरा टेक्स्ट ' 1' के बाद जोड़ा जाता है।

$फेंक दिया 'बैश भाषा' | एसईडी 'एस/(बैश)/जानें 1 प्रोग्रामिंग/'

आउटपुट:

उपरोक्त आदेश को चलाने के बाद निम्न आउटपुट दिखाई देगा। यहां, ' सीखना' पाठ पहले जोड़ा गया है 'दे घुमा के' तथा ' प्रोग्रामिंग ' के बाद टेक्स्ट जोड़ा जाता है दे घुमा के'।

ऊपर जाएँ

12. मेल खाने वाली लाइनें हटाएं

'डी' फ़ाइल से किसी भी लाइन को हटाने के लिए `sed` कमांड में विकल्प का उपयोग किया जाता है। नाम की एक फाइल बनाएं os.txt और के कार्य का परीक्षण करने के लिए निम्नलिखित सामग्री जोड़ें 'डी' विकल्प।

बिल्ली ओएस.txt

खिड़कियाँ
लिनक्स
एंड्रॉयड
आप

निम्नलिखित `sed` कमांड उन पंक्तियों को हटा देगा os.txt फ़ाइल जिसमें टेक्स्ट, 'OS' है।

$बिल्लीos.txt
$एसईडी '/ डी'os.txt

आउटपुट:

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

ऊपर जाएँ

13. मैचिंग लाइन और 2 लाइन मैचिंग लाइन के बाद डिलीट करें

निम्न आदेश फ़ाइल से तीन पंक्तियों को हटा देगा os.txt यदि पैटर्न, ' लिनक्स' पाया जाता है। os.txt में टेक्स्ट है, 'लिनक्स' 'दूसरी पंक्ति में। तो, यह पंक्ति और अगली दो पंक्तियाँ हटा दी जाएँगी।

$एसईडी '/ लिनक्स /, + 2d'os.txt

आउटपुट:

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

ऊपर जाएँ

14. पाठ की पंक्ति के अंत में सभी रिक्त स्थान हटाएं

का उपयोग करते हुए [: रिक्त:] क्लास का उपयोग टेक्स्ट या किसी फ़ाइल की सामग्री से रिक्त स्थान और टैब को हटाने के लिए किया जा सकता है। निम्न आदेश फ़ाइल की प्रत्येक पंक्ति के अंत में रिक्त स्थान को हटा देगा, ओएस.txt.

$बिल्लीos.txt
$एसईडी 'एस/[[:रिक्त:]]*$//'os.txt

आउटपुट:

os.txt प्रत्येक पंक्ति के बाद रिक्त रेखाएँ होती हैं जिन्हें उपरोक्त `sed` कमांड द्वारा हटा दिया जाता है।

ऊपर जाएँ

15. उन सभी पंक्तियों को हटा दें जिनका लाइन पर दो बार मिलान होता है

नाम की एक टेक्स्ट फ़ाइल बनाएँ, इनपुट.txt निम्नलिखित सामग्री के साथ और फ़ाइल की उन पंक्तियों को हटा दें जिनमें खोज पैटर्न दो बार होता है।

इनपुट.txt

PHP एक सर्वर-साइड स्क्रिप्टिंग भाषा है।
PHP एक ओपन-सोर्स भाषा है और PHP केस-संवेदी है।
PHP प्लेटफ़ॉर्म-स्वतंत्र है।

फ़ाइल की दूसरी पंक्ति में 'PHP' टेक्स्ट में दो बार होते हैं, इनपुट.txt . इस उदाहरण में दो `sed` कमांड का उपयोग उन पंक्तियों को हटाने के लिए किया जाता है जिनमें पैटर्न होता है ' पीएचपी ' दो बार। पहला `sed` कमांड प्रत्येक पंक्ति में 'php' की दूसरी घटना को 'द्वारा प्रतिस्थापित करेगा' डेली ' और आउटपुट को दूसरे `sed` कमांड में इनपुट के रूप में भेजें। दूसरा `sed` कमांड उन पंक्तियों को हटा देगा जिनमें टेक्स्ट है, ' डेली '।

$बिल्लीइनपुट.txt
$एसईडी 'एस/php/dl/i2;t'इनपुट.txt| एसईडी '/ डीएल/डी'

आउटपुट:

इनपुट.txt फ़ाइल में दो पंक्तियाँ होती हैं जिनमें पैटर्न होता है, 'php' दो बार। तो, उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा।

ऊपर जाएँ

16. उन सभी पंक्तियों को हटा दें जिनमें केवल सफेद-स्थान है

इस उदाहरण का परीक्षण करने के लिए सामग्री में खाली पंक्तियों वाली किसी भी फ़ाइल का चयन करें। इनपुट.txt पिछले उदाहरण में बनाई गई फ़ाइल में दो खाली लाइनें हैं जिन्हें निम्न `sed` कमांड का उपयोग करके हटाया जा सकता है। यहाँ, '^$' का प्रयोग फाइल में खाली लाइनों का पता लगाने के लिए किया जाता है, इनपुट.txt.

$बिल्लीइनपुट.txt
$एसईडी '/^$/डी'इनपुट.txt

आउटपुट:

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

ऊपर जाएँ

17. सभी गैर-मुद्रण योग्य वर्णों को हटा दें

गैर-मुद्रण योग्य वर्णों को गैर-मुद्रण योग्य वर्णों के स्थान पर किसी भी पाठ से हटाया जा सकता है। [:प्रिंट:] इस उदाहरण में गैर-मुद्रण योग्य वर्णों का पता लगाने के लिए वर्ग का उपयोग किया जाता है। ' ' एक गैर-मुद्रण योग्य वर्ण है और इसे 'इको' कमांड द्वारा सीधे पार्स नहीं किया जा सकता है। इसके लिए, ' ' कैरेक्टर एक वेरिएबल में असाइन किया गया है, $tab जो कि एक 'echo' कमांड में इस्तेमाल होता है। `इको` कमांड का आउटपुट `sed` कमांड में भेजा जाता है जो आउटपुट से वर्ण, ' ' को हटा देगा।

$टैब= $'टी'
$फेंक दिया 'नमस्ते$टैबवर्ल्ड'
$फेंक दिया 'नमस्ते$टैबवर्ल्ड' | एसईडी 'एस/[^[:प्रिंट:]]//जी'

आउटपुट:

उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। पहला `इको कमांड आउटपुट को टैब स्पेस के साथ प्रिंट करेगा और `sed` कमांड टैब स्पेस को हटाने के बाद आउटपुट को प्रिंट करेगा।

ऊपर जाएँ

18. यदि लाइन में कोई मेल है तो लाइन के अंत में कुछ जोड़ें

निम्न कमांड उस पंक्ति के अंत में '10' जोड़ देगा जिसमें टेक्स्ट, 'विंडोज' में शामिल है os.txt फ़ाइल।

$बिल्लीos.txt
$एसईडी '/ विंडोज / एस / $ / 10 /'os.txt

आउटपुट:

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

ऊपर जाएँ

19. यदि लाइन में कोई मेल है तो टेक्स्ट से पहले एक लाइन डालें

निम्नलिखित `sed` कमांड टेक्स्ट को खोजेगा, ' PHP प्लेटफॉर्म-स्वतंत्र है' में इनपुट.txt फ़ाइल जो पहले बनाई गई है। यदि फ़ाइल में यह पाठ किसी भी पंक्ति में है, तो ' PHP एक व्याख्या की गई भाषा है' उस लाइन से पहले डाला जाएगा।

$बिल्लीइनपुट.txt
$एसईडी '/PHP प्लेटफॉर्म-स्वतंत्र है/ s/^/PHP एक व्याख्या की गई भाषा है। /'इनपुट.txt

आउटपुट:

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

ऊपर जाएँ

20. यदि लाइन में मेल है तो उस लाइन के बाद एक लाइन डालें

निम्नलिखित `sed` कमांड टेक्स्ट को खोजेगा, ' लिनक्स' फ़ाइल में os.txt और यदि टेक्स्ट किसी भी लाइन में मौजूद है तो एक नया टेक्स्ट, ' उबंटू ' उस लाइन के बाद डाला जाएगा।

$बिल्लीos.txt
$एसईडी 'एस/लिनक्स/& उबंटू/'os.txt

आउटपुट:

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

ऊपर जाएँ

21. यदि कोई मिलान नहीं है तो पंक्ति के अंत में कुछ जोड़ें

निम्नलिखित `sed` कमांड उन पंक्तियों को खोजेगा os.txt जिसमें पाठ नहीं है, 'लिनक्स' और पाठ संलग्न करें, ' ऑपरेटिंग सिस्टम 'प्रत्येक पंक्ति के अंत में। यहां, ' $ ' प्रतीक का उपयोग उस रेखा की पहचान करने के लिए किया जाता है जहां नया पाठ जोड़ा जाएगा।

$बिल्लीos.txt
$एसईडी '/लिनक्स/! एस/$/ ऑपरेटिंग सिस्टम/'os.txt

आउटपुट:

उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। फ़ाइल os.txt में तीन पंक्तियाँ मौजूद हैं जिनमें टेक्स्ट शामिल नहीं है, 'लिनक्स' और इन पंक्तियों के अंत में जोड़ा गया नया टेक्स्ट।

ऊपर जाएँ

22. यदि कोई मेल नहीं है तो लाइन को हटा दें

नाम की एक फाइल बनाएं वेब.txt और निम्नलिखित सामग्री जोड़ें और उन पंक्तियों को हटा दें जिनमें मेल खाने वाला पैटर्न नहीं है। वेब.txt HTML 5JavaScriptCSSPHPMySQLJQuery निम्नलिखित `sed` कमांड उन पंक्तियों को खोजेगा और हटाएगा जिनमें टेक्स्ट, 'CSS' नहीं है। $ cat web.txt$ sed '/CSS/!d' web.txt आउटपुट: उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। फ़ाइल में एक पंक्ति मौजूद है जिसमें टेक्स्ट, 'सीएसई' है। तो, आउटपुट में सिर्फ एक लाइन होती है।

ऊपर जाएँ

23. टेक्स्ट के बाद स्पेस जोड़ने के बाद मिलान किए गए टेक्स्ट को डुप्लिकेट करें

निम्नलिखित `sed` कमांड फ़ाइल में 'to' शब्द को खोजेगा, अजगर.txt और यदि शब्द मौजूद है तो खोज शब्द के बाद स्थान जोड़कर वही शब्द डाला जाएगा। यहां, '&' डुप्लिकेट टेक्स्ट को जोड़ने के लिए प्रतीक का उपयोग किया जाता है।

$बिल्लीअजगर.txt
$एसईडी -और 'एस / टू / एंड टू / जी'अजगर.txt

आउटपुट:

कमांड चलाने के बाद निम्न आउटपुट दिखाई देगा। यहाँ, फ़ाइल में 'to' शब्द खोजा जाता है, अजगर.txt और यह शब्द इस फ़ाइल की दूसरी पंक्ति में मौजूद है। इसलिए, 'प्रति मेल खाने वाले टेक्स्ट के बाद स्पेस के साथ जोड़ा जाता है।

ऊपर जाएँ

24. स्ट्रिंग्स की एक सूची को नई स्ट्रिंग से बदलें

इस उदाहरण के परीक्षण के लिए आपको दो सूची फ़ाइलें बनानी होंगी। नाम की एक टेक्स्ट फ़ाइल बनाएँ list1.txt और निम्नलिखित सामग्री जोड़ें।

बिल्ली सूची1.txt

1001=>जफर अली
१०२३=>नीर हुसैन
१०६७=>जॉन मिशेल

नाम की एक टेक्स्ट फ़ाइल बनाएँ list2.txt और निम्नलिखित सामग्री जोड़ें।

$ बिल्ली सूची2.txt

1001सीएसई जीपीए3.63
1002सीएसई जीपीए3.24
१०२३सीएसई जीपीए3.11
१०६७सीएसई जीपीए3.84

निम्नलिखित `sed` कमांड ऊपर दिखाई गई दो टेक्स्ट फाइलों के पहले कॉलम से मेल खाएगा और मेल खाने वाले टेक्स्ट को फाइल के तीसरे कॉलम के मान से बदल देगा सूची 1.txt।

$बिल्लीlist1.txt
$बिल्लीlist2.txt
$एसईडी ``बिल्लीlist1.txt| awk '{प्रिंट' -ई के साथ / '$ 1' / '$ 3' / '}'``<<<'`बिल्ली सूची2.txt`'

आउटपुट:

१००१, १०२३ और १०६७ के list1.txt के तीन डेटा के साथ फ़ाइल मिलान list2.txt फ़ाइल और इन मानों को . के तीसरे कॉलम के संगत नामों से बदल दिया जाता है list1.txt .

ऊपर जाएँ

25. मिलान की गई स्ट्रिंग को उस स्ट्रिंग से बदलें जिसमें नई लाइनें हों

निम्न कमांड `इको` कमांड से इनपुट लेगा और शब्द खोजेगा, 'पायथन' लिखित मे। यदि टेक्स्ट में शब्द मौजूद है तो एक नया टेक्स्ट, 'जोड़ा गया पाठ' न्यूलाइन के साथ डाला जाएगा। $ इको बैश पर्ल पायथन जावा पीएचपी एएसपी | sed 's/पायथन/जोड़ा पाठ /' आउटपुट: उपरोक्त आदेश को चलाने के बाद निम्न आउटपुट दिखाई देगा।

ऊपर जाएँ

26. फ़ाइल से नई पंक्तियाँ निकालें और प्रत्येक पंक्ति के अंत में अल्पविराम डालें

निम्न `sed` कमांड फ़ाइल में प्रत्येक नई पंक्ति को अल्पविराम से बदल देगा os.txt . यहां, -साथ में विकल्प का उपयोग लाइन को NULL वर्ण से अलग करने के लिए किया जाता है।

$एसईडी -साथ में 'एस/ /,/जी'os.txt

आउटपुट:

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

ऊपर जाएँ

27. अल्पविराम हटाएं और टेक्स्ट को कई पंक्तियों में विभाजित करने के लिए नई लाइन जोड़ें

निम्नलिखित `sed` कमांड इनपुट के रूप में `echo` कमांड से अल्पविराम से अलग की गई लाइन लेगा और कॉमा को न्यूलाइन से बदल देगा।

$फेंक दिया 'कनिज फातेमा, 30वां, बैच' | एसईडी 'एस/,/एन/जी'

आउटपुट:

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

ऊपर जाएँ

28. केस असंवेदनशील मिलान ढूंढें और लाइन हटाएं

केस-असंवेदनशील मैच के लिए 'I' का उपयोग `sed` कमांड में किया जाता है जो कि इग्नोर केस को इंगित करता है। निम्नलिखित `sed` कमांड उस लाइन को खोजेगा जिसमें शब्द है, 'लिनक्स' ' और लाइन को हटा दें os.txt फ़ाइल।

$बिल्लीos.txt
$एसईडी '/ लिनक्स/आईडी'os.txt

आउटपुट:

उपरोक्त आदेश को चलाने के बाद निम्न आउटपुट दिखाई देगा। os.txt में 'लिनक्स' शब्द है जो पैटर्न से मेल खाता है, केस-असंवेदनशील खोज के लिए 'लिनक्स' और हटा दिया गया है।

ऊपर जाएँ

29. केस असंवेदनशील मिलान ढूंढें और नए टेक्स्ट से बदलें

निम्नलिखित `sed` कमांड `इको` कमांड से इनपुट लेगा और शब्द, 'बैश' को 'PHP' शब्द से बदल देगा।

$फेंक दिया 'मुझे बैश प्रोग्रामिंग पसंद है' | एसईडी 'एस/बैश/PHP/i'

आउटपुट:

उपरोक्त आदेश को चलाने के बाद निम्न आउटपुट दिखाई देगा। यहां, शब्द, 'बैश' शब्द से मेल खाता है, केस-असंवेदनशील खोज के लिए 'बैश' और शब्द 'PHP' द्वारा प्रतिस्थापित किया गया है।

ऊपर जाएँ

30. केस असंवेदनशील मिलान ढूंढें और एक ही टेक्स्ट के सभी अपरकेस से बदलें

' यू' किसी भी टेक्स्ट को सभी बड़े अक्षरों में बदलने के लिए `sed` में प्रयोग किया जाता है। निम्नलिखित `sed` कमांड शब्द को खोजेगा, 'लिनक्स' ' में os.txt फ़ाइल और यदि शब्द मौजूद है तो यह शब्द को सभी बड़े अक्षरों से बदल देगा।

$बिल्लीos.txt
$एसईडी 'एस / (लिनक्स ) / यू 1 / आईजी'os.txt

आउटपुट:

उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। os.txt फ़ाइल के 'लिनक्स' शब्द को 'लिनक्स' शब्द से बदल दिया गया है।

ऊपर जाएँ

31. केस असंवेदनशील मिलान ढूंढें और एक ही टेक्स्ट के सभी लोअरकेस से बदलें

'NS' किसी भी टेक्स्ट को सभी लोअरकेस अक्षरों में बदलने के लिए `sed` में प्रयोग किया जाता है। निम्नलिखित `sed` कमांड शब्द को खोजेगा, 'लिनक्स' में os.txt फ़ाइल करें और शब्द को सभी लोअरकेस अक्षरों से बदलें।

$बिल्लीos.txt
$एसईडी 'एस / (लिनक्स ) / एल 1 / आईजी'os.txt

आउटपुट:

उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। शब्द, 'लिनक्स' को यहाँ 'लिनक्स' शब्द से बदल दिया गया है।

ऊपर जाएँ

32. टेक्स्ट के सभी अपरकेस वर्णों को लोअरकेस वर्णों से बदलें

निम्नलिखित `sed` कमांड सभी अपरकेस वर्णों को खोजेगा os.txt फ़ाइल करें और 'L' का उपयोग करके वर्णों को छोटे अक्षरों से बदलें।

$बिल्लीos.txt
$एसईडी 'एस/(.*)/एल1/'os.txt

आउटपुट:

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

ऊपर जाएँ

33. लाइन में नंबर खोजें और से पहले कोई भी करेंसी सिंबल लगाएं संख्या

नाम की एक फाइल बनाएं आइटम्स.txt निम्नलिखित सामग्री के साथ।

आइटम्स.txt

एचडीडी 100
मॉनिटर 80
माउस 10

निम्नलिखित `sed` कमांड प्रत्येक पंक्ति में संख्या खोजेगा आइटम्स.txt फ़ाइल करें और प्रत्येक संख्या से पहले मुद्रा प्रतीक, '$' संलग्न करें।

$बिल्लीआइटम्स.txt
$एसईडी 'एस / ([0-9] ) / $ 1 / जी'आइटम्स.txt

आउटपुट:

उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। यहाँ, प्रत्येक पंक्ति की संख्या से पहले '$' चिन्ह जोड़ा जाता है।

ऊपर जाएँ

34. उन संख्याओं में अल्पविराम जोड़ें जिनमें 3 से अधिक अंक हों

निम्नलिखित `sed` कमांड `echo` कमांड से इनपुट के रूप में एक संख्या लेगा और दाईं ओर से गिनती के तीन अंकों के प्रत्येक समूह के बाद अल्पविराम जोड़ देगा। यहां, 'ए' लेबल को इंगित करता है और 'टा' का उपयोग समूहीकरण प्रक्रिया को पुनरावृत्त करने के लिए किया जाता है।

$फेंक दिया '5098673' | एसईडी -और:प्रति-और 'एस / (। * [0-9] ) ([0-9] {3 } ) / 1, 2 /; टा'

आउटपुट:

संख्या 5098673 `इको` कमांड में दी गई है और `sed` कमांड ने तीन अंकों के प्रत्येक समूह के बाद अल्पविराम जोड़कर संख्या 5,098,673 उत्पन्न की है।

ऊपर जाएँ

35. टैब कैरेक्टर को 4 स्पेस कैरेक्टर से बदल देता है

निम्नलिखित `sed` कमांड प्रत्येक टैब ( ) वर्ण को चार स्पेस वर्णों से बदल देगा। '$' चिह्न का प्रयोग 'sed' कमांड में टैब कैरेक्टर से मिलान करने के लिए किया जाता है और 'g' का प्रयोग सभी टैब वर्णों को बदलने के लिए किया जाता है।

$फेंक दिया -और '1टी2टी3' | एसईडी$'एस/ टी//जी'

आउटपुट:

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

ऊपर जाएँ

36. लगातार 4 स्पेस कैरेक्टर को टैब कैरेक्टर से बदल देता है

निम्न आदेश लगातार 4 वर्णों को टैब ( ) वर्ण से बदल देगा।

$फेंक दिया -और '1 2' | एसईडी$'एस//टी/जी'

आउटपुट:

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

ऊपर जाएँ

३७. सभी पंक्तियों को पहले ८० वर्णों में काटें

नाम की एक टेक्स्ट फ़ाइल बनाएँ in.txt जिसमें इस उदाहरण का परीक्षण करने के लिए 80 से अधिक वर्णों की रेखाएँ हैं।

in.txt

PHP एक सर्वर-साइड स्क्रिप्टिंग भाषा है।
PHP एक ओपन-सोर्स भाषा है और PHP केस-संवेदी है। PHP प्लेटफ़ॉर्म-स्वतंत्र है।
निम्नलिखित `sed` कमांड की प्रत्येक पंक्ति को छोटा कर देगा in.txt 80 अक्षरों में फाइल करें।

$बिल्लीin.txt
$एसईडी 'एस/(^.{1,80}).*/1/'in.txt

आउटपुट:

उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। In.txt फ़ाइल की दूसरी पंक्ति में 80 से अधिक वर्ण हैं और इस पंक्ति को आउटपुट में छोटा कर दिया गया है।

ऊपर जाएँ

38. एक स्ट्रिंग रेगेक्स की खोज करें और उसके बाद कुछ मानक टेक्स्ट संलग्न करें

निम्नलिखित `sed` कमांड टेक्स्ट को खोजेगा, ' नमस्ते 'इनपुट टेक्स्ट में और टेक्स्ट संलग्न करें,' जॉन 'उस पाठ के बाद।

$फेंक दिया 'नमस्ते कैसी हो तुम?' | एसईडी 'एस/(हैलो)/1 जॉन/'

आउटपुट:

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

ऊपर जाएँ

39. स्ट्रिंग रेगेक्स की खोज करें और प्रत्येक पंक्ति में दूसरे मैच के बाद कुछ टेक्स्ट संलग्न करें

निम्नलिखित `sed` कमांड टेक्स्ट को खोजेगा, ' पीएचपी ' की प्रत्येक पंक्ति में इनपुट.txt और पाठ के साथ प्रत्येक पंक्ति में दूसरे मिलान को बदलें, 'नया पाठ जोड़ा गया' .

$बिल्लीइनपुट.txt
$एसईडी 's/(PHP)/1 (नया टेक्स्ट जोड़ा गया)/2'इनपुट.txt

आउटपुट:

उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। खोज पाठ, ' पीएचपी की दूसरी और तीसरी पंक्तियों में दो बार प्रकट होता है इनपुट.txt फ़ाइल। तो, पाठ, ' नया पाठ जोड़ा गया ' दूसरी और तीसरी पंक्तियों में डाला गया है।

ऊपर जाएँ

40. एक फ़ाइल से बहु-पंक्ति `sed` स्क्रिप्ट चलाना

एक फ़ाइल में एकाधिक `sed` लिपियों को संग्रहीत किया जा सकता है और सभी लिपियों को `sed` कमांड चलाकर एक साथ निष्पादित किया जा सकता है। नाम की एक फाइल बनाएं 'सेडसीएमडी' ' और निम्नलिखित सामग्री जोड़ें। यहाँ, फ़ाइल में दो `sed` स्क्रिप्ट जोड़ी जाती हैं। एक स्क्रिप्ट टेक्स्ट की जगह ले लेगी, ' पीएचपी ' द्वारा 'एएसपी' ' एक और स्क्रिप्ट टेक्स्ट की जगह ले लेगी, ' स्वतंत्र 'पाठ द्वारा,' आश्रित '।

sedcmd

एस/पीएचपी/एएसपी/
एस/स्वतंत्र/आश्रित/

निम्नलिखित `sed` कमांड सभी 'PHP' और 'स्वतंत्र' टेक्स्ट को 'ASP' और 'आश्रित' से बदल देगा। यहाँ, फ़ाइल से `sed` स्क्रिप्ट को निष्पादित करने के लिए `sed` कमांड में '-f' विकल्प का उपयोग किया जाता है।

$बिल्लीsedcmd
$एसईडी -एफsedcmd input.txt

आउटपुट:

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

ऊपर जाएँ

41. एक बहु-पंक्ति पैटर्न का मिलान करें और नए बहु-पंक्ति पाठ के साथ बदलें

निम्नलिखित `sed` कमांड बहु-पंक्ति पाठ की खोज करेगा, 'लिनक्स एंड्रॉयड' और यदि पैटर्न मेल खाता है तो मेल खाने वाली लाइनों को मल्टी-लाइन टेक्स्ट से बदल दिया जाएगा, 'उबंटू एंड्रॉयड लॉलीपॉप '। यहां, P और D का उपयोग मल्टीलाइन प्रोसेसिंग के लिए किया जाता है।

$बिल्लीos.txt
$एसईडी '$!N;s/Linux Andoid/Ubuntu Andoid Lollipop/;P;D'os.txt

आउटपुट:

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

ऊपर जाएँ

42. एक पैटर्न से मेल खाने वाले टेक्स्ट में दो शब्दों के क्रम को बदलें

निम्नलिखित `sed` कमांड `echo` कमांड से दो शब्दों का इनपुट लेगा और इन शब्दों के क्रम को बदल देगा।

$फेंक दिया 'पर्ल पायथन' | एसईडी -और 's/([^ ]*) *([^ ]*)/2 1/'

आउटपुट:

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

ऊपर जाएँ

43. कमांड लाइन से कई `sed` कमांड निष्पादित करें

कमांड लाइन से कई `sed` स्क्रिप्ट चलाने के लिए `sed` कमांड में '-e' विकल्प का उपयोग किया जाता है। निम्नलिखित `sed` कमांड `इको` कमांड से इनपुट के रूप में एक टेक्स्ट लेगा और 'की जगह लेगा' उबंटू ' द्वारा ' कुबंटु ' तथा ' सैकड़ों ' द्वारा ' फेडोरा '।

$फेंक दिया 'उबंटू सेंटोस डेबियन' | एसईडी -और एस/उबंटू/कुबंटू/; एस/सेंटोस/फेडोरा/'

आउटपुट:

उपरोक्त आदेश को चलाने के बाद निम्न आउटपुट दिखाई देगा। यहां, 'उबंटू' और 'सेंटोस' को 'कुबंटू' और 'फेडोरा' से बदल दिया गया है।

ऊपर जाएँ

44. `sed` को अन्य कमांड के साथ मिलाएं

निम्न कमांड `sed` कमांड को `cat` कमांड के साथ जोड़ देगा। पहला `sed` कमांड से इनपुट लेगा os.txt फ़ाइल और कमांड के आउटपुट को 'फेडोरा' द्वारा 'लिनक्स' टेक्स्ट को बदलने के बाद दूसरे `sed` कमांड को भेजें। दूसरा `sed` कमांड टेक्स्ट, 'विंडोज' को 'विंडोज 10' से बदल देगा।

$बिल्लीos.txt| एसईडी 'एस/लिनक्स/फेडोरा/'| एसईडी / विंडोज़ / विंडोज 10 / आई'

आउटपुट:

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

ऊपर जाएँ

45. एक फाइल में खाली लाइन डालें

नाम की एक फाइल बनाएं एसटीडीलिस्ट निम्नलिखित सामग्री के साथ।

एसटीडीलिस्ट

#आईडी #नाम
[१०१] -परंतु
[102] -नेहा

फ़ाइल में खाली लाइन डालने के लिए 'G' विकल्प का उपयोग किया जाता है। निम्नलिखित `sed` कमांड प्रत्येक पंक्ति के बाद खाली लाइनें सम्मिलित करेगा एसटीडीलिस्ट फ़ाइल।

$बिल्लीएसटीडीलिस्ट
$एसईडीजी stdlist

आउटपुट:

उपरोक्त आदेशों को चलाने के बाद निम्न आउटपुट दिखाई देगा। फ़ाइल की प्रत्येक पंक्ति के बाद एक खाली लाइन डाली जाती है।

ऊपर जाएँ

46. ​​फ़ाइल की प्रत्येक पंक्ति में सभी अल्फा-न्यूमेरिक वर्णों को स्थान से बदलें।

निम्न आदेश सभी अल्फा-न्यूमेरिक वर्णों को अंतरिक्ष में बदल देगा एसटीडीलिस्ट फ़ाइल।

$बिल्लीएसटीडीलिस्ट
$लेकिन 'एस / [ए-ज़ा-जेड0-9] // जी'एसटीडीलिस्ट

आउटपुट:

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

ऊपर जाएँ

47. मिलान वाली स्ट्रिंग को प्रिंट करने के लिए '&' का प्रयोग करें

निम्न कमांड 'L' से शुरू होने वाले शब्द को खोजेगा और टेक्स्ट को जोड़कर बदल देगा 'मिला हुआ स्ट्रिंग है - 'और' चिह्न का प्रयोग करके सुमेलित शब्द के साथ। यहाँ 'p' का प्रयोग संशोधित टेक्स्ट को प्रिंट करने के लिए किया जाता है।

$एसईडी -एन 's/^L/मिलान स्ट्रिंग है - &/p'os.txt

आउटपुट:

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

ऊपर जाएँ

48. किसी फ़ाइल में शब्दों के युग्म स्विच करें

नाम की एक टेक्स्ट फ़ाइल बनाएँ कोर्स.txt निम्नलिखित सामग्री के साथ जिसमें प्रत्येक पंक्ति में शब्दों की जोड़ी है।

कोर्स.txt

पीएचपी एएसपी
मायएसक्यूएल ओरेकल
कोडइग्निटर लारवेल

निम्न आदेश फ़ाइल की प्रत्येक पंक्ति में शब्दों की जोड़ी को बदल देगा, कोर्स.txt .

$एसईडी 's/([^ ]*) *([^ ]*)/2 1/'कोर्स.txt

आउटपुट:

प्रत्येक पंक्ति में शब्दों की जोड़ी को बदलने के बाद निम्न आउटपुट दिखाई देगा।

ऊपर जाएँ

49. प्रत्येक शब्द के पहले अक्षर को बड़ा करें

निम्नलिखित `sed` कमांड `इको` कमांड से इनपुट टेक्स्ट लेगा और प्रत्येक शब्द के पहले अक्षर को एक बड़े अक्षर में बदल देगा।

$फेंक दिया 'मुझे बैश प्रोग्रामिंग पसंद है' | एसईडी 's / ([a-z] ) [[a-zA-Z0-9] * ) / u 1 2 / g'

आउटपुट:

उपरोक्त आदेश को चलाने के बाद निम्न आउटपुट दिखाई देगा। इनपुट टेक्स्ट, आई लाइक बैश प्रोग्रामिंग पहले शब्द को कैपिटल करने के बाद आई लाइक बैश प्रोग्रामिंग के रूप में प्रिंट किया जाता है।

ऊपर जाएँ

५०. फाइल के लाइन नंबर प्रिंट करें

फ़ाइल की प्रत्येक पंक्ति से पहले लाइन नंबर को प्रिंट करने के लिए '=' प्रतीक का उपयोग `sed` कमांड के लिए किया जाता है। निम्न आदेश की सामग्री मुद्रित करेगा os.txt लाइन नंबर के साथ फाइल।

$एसईडी '='os.txt

आउटपुट:

उपरोक्त आदेश को चलाने के बाद निम्न आउटपुट दिखाई देगा। में चार पंक्तियाँ हैं os.txt फ़ाइल। तो, फ़ाइल की प्रत्येक पंक्ति से पहले लाइन नंबर मुद्रित होता है।

ऊपर जाएँ

निष्कर्ष:

इस ट्यूटोरियल में `sed` कमांड के विभिन्न उपयोगों को बहुत ही सरल उदाहरणों का उपयोग करके समझाया गया है। यहां उल्लिखित सभी `sed` लिपियों का आउटपुट अस्थायी रूप से उत्पन्न होता है और मूल फ़ाइल की सामग्री अपरिवर्तित रहती है। लेकिन आप चाहें तो `sed कमांड के –i या –in-place विकल्प का उपयोग करके मूल फ़ाइल को संशोधित कर सकते हैं। यदि आप एक नए लिनक्स उपयोगकर्ता हैं और विभिन्न प्रकार के स्ट्रिंग मैनिपुलेशन कार्यों को करने के लिए `sed` कमांड के मूल उपयोग सीखना चाहते हैं, तो यह ट्यूटोरियल आपकी मदद करेगा। इस ट्यूटोरियल को पढ़ने के बाद, आशा है, किसी भी उपयोगकर्ता को `sed` कमांड के कार्यों के बारे में स्पष्ट अवधारणा मिल जाएगी।

अक्सर पूछे जाने वाले प्रश्न

सेड कमांड किसके लिए प्रयोग किया जाता है?

sed कमांड के कई अलग-अलग उपयोग हैं। कहा जा रहा है, मुख्य उपयोग किसी फ़ाइल में शब्दों को प्रतिस्थापित करने, या खोजने और बदलने के लिए है।

Sed के बारे में सबसे अच्छी बात यह है कि आप किसी फ़ाइल में एक शब्द खोज सकते हैं और उसे बदल सकते हैं, लेकिन आपको कभी भी फ़ाइल को खोलना नहीं है - sed यह सब आपके लिए करता है!

साथ ही इसे डिलीट करने के लिए भी इस्तेमाल किया जा सकता है। आपको बस उस शब्द को टाइप करना है जिसे आप ढूंढना, बदलना या हटाना चाहते हैं, और यह आपके लिए इसे लाता है - फिर आप उस शब्द को बदलना चुन सकते हैं या अपनी फ़ाइल से शब्द के सभी निशान हटा सकते हैं।

आईपी ​​​​पते जैसी चीजों को बदलने में सक्षम होने के लिए sed एक शानदार उपकरण है और ऐसी कोई भी चीज जो अत्यधिक संवेदनशील है जिसे आप अन्यथा फ़ाइल में नहीं रखना चाहते हैं। sed किसी भी सॉफ्टवेयर इंजीनियर के लिए जरूरी है!

Sed कमांड में S और G क्या होता है?

अपने सबसे सरल शब्दों में, S फ़ंक्शन जिसका उपयोग sed में किया जा सकता है, का अर्थ है 'विकल्प'। S टाइप करने के बाद आप अपनी इच्छानुसार कुछ भी बदल सकते हैं या प्रतिस्थापित कर सकते हैं - बस S टाइप करने से केवल एक लाइन पर शब्द की पहली आवृत्ति बदल जाएगी।

इसलिए, यदि आपके पास एक वाक्य या पंक्ति है जो एक से अधिक बार इसका उल्लेख करती है, तो एस फ़ंक्शन आदर्श नहीं है क्योंकि यह केवल पहली घटना को प्रतिस्थापित करेगा। आप एक पैटर्न निर्दिष्ट कर सकते हैं ताकि S हर दो बार में शब्दों को बदल सके।

sed कमांड के अंत में G निर्दिष्ट करना एक वैश्विक प्रतिस्थापन करेगा (यही G का अर्थ है)। इसे ध्यान में रखते हुए, यदि आप G निर्दिष्ट करते हैं तो यह आपके द्वारा चुने गए शब्द की प्रत्येक घटना को प्रतिस्थापित करेगा, न कि केवल पहली घटना जो S करता है।

मैं एक sed स्क्रिप्ट कैसे चला सकता हूँ?

आप एक सेड स्क्रिप्ट को कई तरीकों से चला सकते हैं लेकिन कमांड लाइन पर सबसे आम है। यहां आप केवल sed और वह फ़ाइल निर्दिष्ट कर सकते हैं जिस पर आप कमांड का उपयोग करना चाहते हैं।

यह आपको उस फ़ाइल पर sed का उपयोग करने की अनुमति देता है, जिससे आप आवश्यकतानुसार ढूंढ सकते हैं, हटा सकते हैं और स्थानापन्न कर सकते हैं।

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

ध्यान रखें कि यह निश्चित रूप से केवल लिनक्स पर उपलब्ध है, और इसलिए आपको अपनी sed स्क्रिप्ट को चलाने के लिए यह सुनिश्चित करने की आवश्यकता होगी कि आपके पास एक Linux कमांड लाइन है।