Visual Basic for Applications:
स्ट्रिंग से कोट्स हटाना
कैसे:
VBA में, एक स्ट्रिंग से उद्धरण चिह्नों को हटाने के लिए कई तरीके हैं। यहाँ Replace
फंक्शन का उपयोग करके एक सीधा उदाहरण है, जो स्ट्रिंग में विशिष्ट उप-स्ट्रिंग (इस मामले में, एक उद्धरण) की खोज करता है और उसे दूसरे उप-स्ट्रिंग के साथ बदलता है (हटाने के लिए एक खाली स्ट्रिंग)।
Sub RemoveQuotesExample()
Dim originalString As String
originalString = "'This' is a ""test"" string."
' एकल उद्धरण हटाएं
originalString = Replace(originalString, "'", "")
' दोहरे उद्धरण हटाएं
originalString = Replace(originalString, Chr(34), "")
Debug.Print originalString 'आउटपुट: This is a test string.
End Sub
ध्यान दें कि दोहरे उद्धरणों के लिए, हम Chr(34)
का उपयोग करते हैं क्योंकि एक दोहरा उद्धरण ASCII चरित्र 34 है। VBA में स्ट्रिंग लिटरल्स को दर्शाने के लिए भी दोहरे उद्धरणों का उपयोग किया जाता है, इसलिए यह आवश्यक है।
अधिक जटिल परिस्थितियों में जहाँ उद्धरण आवश्यक फॉर्मेटिंग का हिस्सा हो सकते हैं (जैसे कि एक उद्धृत शब्द के भीतर), अधिक सूक्ष्म तर्क, शायद Regex या वर्ण द्वारा वर्ण पार्सिंग की आवश्यकता हो सकती है।
गहन अध्ययन
VBA, Microsoft Office सूट के भीतर कार्यों को स्वचालित करने में एक मुख्य भूमिका निभाने वाला, स्ट्रिंग मैनिपुलेशन फंक्शंस का एक समृद्ध सेट प्रदान करता है, जिसमें Replace
सबसे अधिक उपयोग किए जाने वाले में से एक है। हालांकि, यह फंक्शन, VBA के साथ स्ट्रिंग मैनिपुलेशन के संदर्भ में प्राप्त की जा सकने वाली संभावनाओं की सतह को ही खुरचता है।
इतिहासिक रूप से, VBA ने अपने पूर्ववर्तियों से कार्यालय स्वचालन कार्यों के लिए सरलता पर जोर दिया, इसलिए Replace
जैसे फंक्शंस के सीधा कार्यान्वयन। हालांकि, आधुनिक प्रोग्रामिंग कार्यों के लिए, विशेष रूप से जटिल स्ट्रिंग मैनिपुलेशंस या सफाई को शामिल करते हुए, VBA अपनी सीमाएँ दिखा सकता है।
ऐसे मामलों में, प्रोग्रामर VBScript_RegExp_55.RegExp
ऑब्जेक्ट के माध्यम से नियमित अभिव्यक्तियों (regular expressions) के साथ VBA को जोड़कर अधिक लचीलेपन और शक्ति की तलाश कर सकते हैं, जब स्ट्रिंग्स को पार्स और मैनिपुलेट करने की बात आती है। हालांकि, यह दृष्टिकोण अतिरिक्त जटिलता जोड़ता है और रेगेक्स पैटर्न की मजबूत समझ की आवश्यकता होती है, जो सभी उपयोगकर्ताओं के लिए उपयुक्त नहीं हो सकती है।
इसकी सीमाओं के बावजूद, VBA का Replace
फंक्शन स्ट्रिंग्स से उद्धरण हटाने के कई सामान्य परिस्थितियों को कुशलतापूर्वक कवर करता है। यह अधिक जटिल regex क्षेत्र में डुबकी लगाए बिना अधिकांश स्ट्रिंग मैनिपुलेशन आवश्यकताओं के लिए एक त्वरित और आसान समाधान प्रदान करता है। जो लोग Replace
और अन्य मूलभूत स्ट्रिंग फंक्शंस की सीमाओं तक पहुँच चुके हैं, VBA के भीतर regex का पता लगाने या जटिल स्ट्रिंग ऑपरेशनों के लिए अधिक मजबूत भाषा पर विचार करना अगला सर्वोत्तम कदम हो सकता है।