sed
एपीआई आदिम है - और यह डिजाइन द्वारा है। कम से कम, यह डिजाइन के द्वारा आदिम बना हुआ है - चाहे इसे आदिम रूप से डिजाइन किया गया हो, मैं नहीं कह सकता। ज्यादातर मामलों में एक sed
स्क्रिप्ट का लेखन , जो जब चलता है, तो दूसरी sed
स्क्रिप्ट को आउटपुट करेगा, वास्तव में एक साधारण मामला है। sed
इस तरह से m4
और / या मैक्रो प्रीप्रोसेसर द्वारा बहुत बार लागू किया जाता है make
।
(निम्न प्रकार एक अत्यधिक काल्पनिक उपयोग मामला है: यह एक समाधान के अनुरूप करने के लिए इंजीनियर की समस्या है। यदि यह आपके लिए एक खिंचाव की तरह महसूस करता है, तो शायद ऐसा इसलिए है क्योंकि यह है, लेकिन यह जरूरी नहीं कि इसे कोई कम वैध बना दे।)
निम्नलिखित इनपुट फ़ाइल पर विचार करें:
cat <<"" >./infile
camel
cat dog camel
dog cat
switch
upper
lower
यदि हम एक sed
स्क्रिप्ट लिखना चाहते हैं, जो उपरोक्त इनपुट फ़ाइल में प्रत्येक उपयुक्त शब्द की पूंछ पर शब्द -केस जोड़ देगा, अगर यह उचित संदर्भ में एक पंक्ति में पाया जा सकता है , और हम यथासंभव कुशलता से ऐसा करना चाहते हैं ( जैसा कि हमारा लक्ष्य होना चाहिए, उदाहरण के लिए, एक संकलन ऑपरेशन के दौरान) तो हमें जितना संभव हो सके regexp s लगाने से बचना चाहिए ।/
/
एक चीज जो हम कर सकते हैं वह है कि अभी हमारे सिस्टम पर फ़ाइल को पूर्व-संपादित करें, और sed
संकलन के दौरान कभी भी कॉल न करें । लेकिन अगर फ़ाइल में कोई भी शब्द स्थानीय सेटिंग्स और / या संकलन-समय के विकल्पों के आधार पर शामिल होना चाहिए या नहीं होना चाहिए, तो ऐसा करने की संभावना एक वांछनीय विकल्प नहीं होगी।
एक और चीज़ जो हम कर सकते हैं वह है फ़ाइल को अब regexps के विरुद्ध संसाधित करना । हम उत्पादन कर सकते हैं - और हमारे संकलन में शामिल हैं - एक sed
स्क्रिप्ट जो पंक्ति संख्या के अनुसार संपादन लागू कर सकती है - जो आमतौर पर लंबे समय में अधिक कुशल मार्ग है।
उदाहरण के लिए:
n=$(printf '\\\n\t')
grep -En 'camel|upper|lower' <infile |
sed " 1i${n%?}#!/usr/heirloom/bin/posix2001/sed -nf
s/[^:]*/:&$n&!n;&!b&$n&/;s/://2;\$a${n%?}q"'
s/ *cat/!/g;s/ *dog/!/g
s| *\([cul][^ ]*\).*|s/.*/\1-case/p|'
... जो sed
स्क्रिप्ट के रूप में आउटपुट लिखता है और जो दिखता है ...
#!/usr/heirloom/bin/posix2001/sed -nf
:1
1!n;1!b1
1s/.*/camel-case/p
:2
2!n;2!b2
2!!s/.*/camel-case/p
:5
5!n;5!b5
5s/.*/upper-case/p
:6
6!n;6!b6
6s/.*/lower-case/p
q
जब उस आउटपुट को मेरी मशीन पर एक निष्पादन योग्य पाठ फ़ाइल में सहेजा जाता है, जिसका नाम है ./bang.sed
और जैसे है ./bang.sed ./infile
, आउटपुट है:
camel-case
upper-case
lower-case
अब आप मुझसे पूछ सकते हैं ... मैं ऐसा क्यों करना चाहूंगा? मैं सिर्फ एंकर grep
के मैच क्यों नहीं करूंगा ? वैसे भी ऊंट-केस का उपयोग कौन करता है? और प्रत्येक प्रश्न के लिए मैं केवल उत्तर दे सकता था, मुझे कोई पता नहीं है ... क्योंकि मैं नहीं करता। इस सवाल को पढ़ने से पहले मैंने कभी व्यक्तिगत रूप से बहु पर ध्यान नहीं दिया था ! युक्ति में आवश्यकता को पार्स करना - मुझे लगता है कि यह एक बहुत साफ पकड़ है।
बहु! बात की थी की बहुत - तुरंत हालांकि, मेरे लिए कोई मतलब sed
विनिर्देश बस पार्स और बस की ओर तैयार है उत्पन्न sed
स्क्रिप्ट। संभवतः आपको उस संदर्भ में बहुत अधिक समझ बनाने के \n
लिए आवश्यक ईवलाइन सीमांकक मिल जाएगा [wr:bt{]
, और यदि आप उस विचार को ध्यान में रखते हैं, तो आप कल्पना के कुछ अन्य पहलुओं के बारे में बेहतर समझ बना सकते हैं - (जैसे :
बिना पते के स्वीकार करना, और q
मना करना 1 से अधिक किसी को भी स्वीकार करें) ।
उदाहरण में ऊपर मैं की एक निश्चित फ़ॉर्म को लिखना sed
जो केवल कर सकते हैं स्क्रिप्ट कभी एक बार पढ़ा जा। यदि आप इसे मुश्किल से देखते हैं तो आप देख सकते हैं कि जैसा कि sed
एडिट-फाइल को पढ़ता है यह एक कमांड-ब्लॉक से अगले तक बढ़ता है - यह कभी भी अपनी एडिट-फाइल के माध्यम से पूरी तरह से इसके एडिट-स्क्रिप्ट से दूर नहीं होता है या इसकी एडिट-स्क्रिप्ट को पूरा नहीं करता है।
मुझे लगता है कि बहु-! पते कुछ अन्य की तुलना में उस संदर्भ में अधिक उपयोगी हो सकते हैं, लेकिन, ईमानदारी से, मैं एक भी मामले के बारे में नहीं सोच सकता जिसमें मैंने इसे बहुत अच्छे उपयोग के लिए रखा हो - और मैं sed
बहुत कुछ। मुझे यह भी उल्लेखनीय है कि GNU / BSD sed
दोनों ही इसे निर्दिष्ट करने में विफल रहते हैं - यह संभवतः उस कल्पना का एक पहलू नहीं है जो बहुत अधिक मांग में है, और इसलिए यदि कोई कार्यान्वयन इसे नजरअंदाज करता है, तो मुझे संदेह है कि उनके कीड़े @ बॉक्स को बहुत ही पीड़ा देंगे परिणामस्वरूप।
जिसके अनुसार, विफलता निर्दिष्ट के रूप में इस संभाल करने के लिए है किसी भी लागू करने के लिए एक बग जो अनुपालन का दिखावा, और इसलिए मैं प्रासंगिक देव बक्से कहा जाता है-के लिए यहाँ है के लिए एक ईमेल शूटिंग लगता है, और मैं अगर तुम नहीं ऐसा करने के लिए करना चाहते हैं।
!
एक टॉगल के रूप में कार्य करता है,/pattern/!!
जैसा है/pattern/
, और/pattern/!!!
जैसा है वैसा ही है/pattern/!
। FreeBSD पर!
एक एकल के रूप में कई हैं।