Hi everyone! I'm the author of code.mu :)
I'd love to chat with my non-Russian audience. I'm looking for your feedback on the site and the translation quality. Let's chat:)
⊗pyPmREESCh 36 of 129 menu

पायथन में रेगुलर एक्सप्रेशन में विशेष वर्णों को एस्केप करना

मान लीजिए कि आप चाहते हैं कि एक विशेष वर्ण स्वयं का प्रतिनिधित्व करे। इसके लिए आपको बैकस्लैश का उपयोग करके इसे एस्केप करना होगा। आइए उदाहरणों से समझते हैं।

उदाहरण

निम्नलिखित उदाहरण में, रेगुलर एक्सप्रेशन के लेखक चाहते थे कि खोज पैटर्न इस तरह दिखे: अक्षर 'a', फिर प्लस चिह्न '+', फिर अक्षर 'x'। हालाँकि, कोड के लेखक ने '+' वर्ण को एस्केप नहीं किया और इसलिए वास्तव में खोज पैटर्न इस तरह दिखता है: अक्षर 'a' एक या अधिक बार, फिर अक्षर 'x':

txt = 'a+x ax aax aaax' res = re.sub('a+x', '!', txt) print(res)

कोड निष्पादन का परिणाम:

'a+x ! ! !'

उदाहरण

और अब लेखक ने प्लस चिह्न को बैकस्लैश से एस्केप कर दिया है। अब खोज पैटर्न वैसा ही दिखता है, जैसा होना चाहिए: अक्षर 'a', फिर प्लस चिह्न '+', फिर अक्षर 'x':

txt = 'a+x ax aax aaax' res = re.sub('a\+x', '!', txt) print(res)

कोड निष्पादन का परिणाम:

'! ax aax aaax'

उदाहरण

इस उदाहरण में, पैटर्न इस तरह दिखता है: अक्षर 'a', फिर डॉट '.', फिर अक्षर 'x':

txt = 'a.x abx azx' res = re.sub('a\.x', '!', txt) print(res)

कोड निष्पादन का परिणाम:

'! abx azx'

उदाहरण

निम्नलिखित उदाहरण में, लेखक स्लैश को एस्केप करना भूल गया और रेगुलर एक्सप्रेशन ने सभी सबस्ट्रिंग को पकड़ लिया, क्योंकि अनएस्केप्ड डॉट किसी भी वर्ण का प्रतिनिधित्व करती है:

txt = 'a.x abx azx' res = re.sub('a.x', '!', txt) print(res)

कोड निष्पादन का परिणाम:

'! ! !'

टिप्पणी

ध्यान दें कि यदि आप डॉट के लिए बैकस्लैश भूल जाते हैं (जब उसे स्वयं का प्रतिनिधित्व करना चाहिए) - इसपर ध्यान नहीं जा सकता है:

res = re.sub('a.x', '!', 'a.x') print(res) # '!' लौटाएगा, जैसा हम चाहते थे

दृष्टिगत रूप से यह सही ढंग से काम करता है (क्योंकि डॉट किसी भी वर्ण का प्रतिनिधित्व करती है, जिसमें सामान्य डॉट '.' भी शामिल है)। लेकिन यदि वह स्ट्रिंग बदल दें, जिसमें प्रतिस्थापन हो रहा है - तो हम अपनी गलती देखेंगे:

res = re.sub('a.x', '!', 'a.x abx azx') print(res) # '! ! !' लौटाएगा, जबकि अपेक्षा थी '! abx azx'

विशेष वर्णों और सामान्य वर्णों की सूची

यदि एक सामान्य वर्ण को एस्केप कर दें - तो कुछ बुरा नहीं होगा - वह फिर भी स्वयं का प्रतिनिधित्व करेगा। इसका अपवाद - अंक हैं, उन्हें एस्केप नहीं किया जा सकता।

अक्सर संदेह उत्पन्न होता है कि क्या दिया गया वर्ण विशेष है। कुछ लोग तो सभी संदिग्ध वर्णों को एक के बाद एक एस्केप करने लगते हैं। हालाँकि, यह एक बुरी आदत है (यह रेगुलर एक्सप्रेशन को बैकस्लैश से अव्यवस्थित कर देती है)।

विशेष वर्ण हैं: $ ^ . * + ? \ / {} [] () |

विशेष वर्ण नहीं हैं: @ : , ' " - _ = < > % # ~ `& !

व्यावहारिक समस्याएं

एक स्ट्रिंग दी गई है:

txt = 'a.a aba aea'

एक रेगुलर एक्सप्रेशन लिखें, जो स्ट्रिंग 'a.a' को ढूंढे, बाकी को नहीं।

एक स्ट्रिंग दी गई है:

txt = '2+3 223 2223'

एक रेगुलर एक्सप्रेशन लिखें, जो स्ट्रिंग '2+3' को ढूंढे, बाकी को नहीं।

एक स्ट्रिंग दी गई है:

txt = '23 2+3 2++3 2+++3 345 567'

एक रेगुलर एक्सप्रेशन लिखें, जो स्ट्रिंग्स '2+3', '2++3', '2+++3', को ढूंढे, बाकी को नहीं (+ कितनी भी संख्या में हो सकता है)।

एक स्ट्रिंग दी गई है:

txt = '23 2+3 2++3 2+++3 445 677'

एक रेगुलर एक्सप्रेशन लिखें, जो स्ट्रिंग्स '23', '2+3', '2++3', '2+++3', को ढूंढे, बाकी को नहीं।

एक स्ट्रिंग दी गई है:

txt = '*+ *q+ *qq+ *qqq+ *qqq qqq+'

एक रेगुलर एक्सप्रेशन लिखें, जो स्ट्रिंग्स '*q+', '*qq+', '*qqq+', को ढूंढे, बाकी को नहीं।

एक स्ट्रिंग दी गई है:

txt = '[abc] {abc} abc (abc) [abc]'

एक रेगुलर एक्सप्रेशन लिखें, जो वर्गाकार कोष्ठकों वाली स्ट्रिंग्स को ढूंढे और उन्हें '!' से बदल दे।

हिन्दी
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें