एक्सेल डेटा मान्यता नियमित अभिव्यक्ति का उपयोग कर (Regex)

  • इसे साझा करें
Michael Brown

ट्यूटोरियल दिखाता है कि कस्टम RegexMatch फ़ंक्शन की मदद से रेगुलर एक्सप्रेशन का उपयोग करके Excel में डेटा सत्यापन कैसे किया जाता है।

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

    रेगेक्स के साथ एक्सेल डेटा सत्यापन कैसे करें

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

    1. एक कस्टम रेगेक्स फ़ंक्शन बनाएं जो यह जांचता है कि इनपुट मान एक रेगुलर एक्सप्रेशन से मेल खाता है या नहीं।
    2. अपने रेगेक्स फॉर्मूला के लिए एक नाम परिभाषित करें।
    3. नामित सूत्र के आधार पर डेटा सत्यापन नियम कॉन्फ़िगर करें।
    4. प्रतिलिपि बनाएँआप जितने चाहें उतने सेल के लिए सत्यापन सेटिंग्स।

    एक योजना की तरह लगता है? आइए इसे अभ्यास में लागू करने का प्रयास करें!

    कस्टम रेगुलर एक्सप्रेशंस का उपयोग करते हुए एक्सेल डेटा सत्यापन

    यह उदाहरण एक बहुत ही सामान्य मामले को संबोधित करता है - केवल एक विशिष्ट पैटर्न के मूल्यों को कैसे अनुमति दें।

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

    पैटर्न : ^[A-Z]{3}-\d{3}$

    कृपया ध्यान दें कि स्ट्रिंग का प्रारंभ (^) और अंत ($) एंकर हैं, इसलिए इसमें के अलावा कोई वर्ण नहीं है एक सेल में पैटर्न दर्ज किया जा सकता है।

    1। एक कस्टम रेगेक्स मैच फ़ंक्शन जोड़ें

    अपनी कार्यपुस्तिका में RegExpMatch फ़ंक्शन सम्मिलित करके प्रारंभ करें। कोड पहले से ही हमारे एक्सेल गुरुओं द्वारा लिखा गया है, इसलिए आपको इसे ऊपर दिए गए लिंक पेज से कॉपी करना होगा और अपने वीबीए संपादक में पेस्ट करना होगा।

    आपके संदर्भ के लिए फ़ंक्शन का सिंटैक्स यहां दिया गया है:

    RegExpMatch(text) , पैटर्न, [मैच_केस])

    कहां:

    • टेक्स्ट (आवश्यक) - एक स्रोत स्ट्रिंग (हमारे संदर्भ में - एक मान्य सेल)।
    • <9 पैटर्न (आवश्यक) - मिलान करने के लिए एक रेगुलर एक्सप्रेशन।
    • Match_case (वैकल्पिक) - मिलान प्रकार। सही या छोड़ा गया - मामला-संवेदनशील; FALSE - केस-संवेदी।

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

    2। एक नामांकित सूत्र बनाएं

    अपने लक्ष्य वर्कशीट में, सेल A1 का चयन करें (इसकी सामग्री की परवाह किए बिना और कोई फर्क नहीं पड़ता कि आप वास्तव में किस सेल को मान्य करने जा रहे हैं), नाम प्रबंधक खोलने के लिए Ctrl + F3 दबाएं, और एक नाम परिभाषित करें इस सूत्र के लिए:

    =RegExpMatch(Sheet1!A1, "^[A-Z]{3}-\d{3}$")

    या आप कुछ सेल में रेगेक्स दर्ज कर सकते हैं (इस उदाहरण में A2) और दूसरे तर्क के लिए $A$2 की आपूर्ति करें:

    =RegExpMatch(Sheet1!A1, Sheet1!$A$2)

    फ़ॉर्मूला के सही तरीके से काम करने के लिए, टेक्स्ट तर्क (A1) के लिए सापेक्ष संदर्भ और पैटर्न ($A$2) के लिए निरपेक्ष संदर्भ का उपयोग करना सुनिश्चित करें।

    यह देखते हुए कि हमारा फॉर्मूला SKU नंबरों को मान्य करने के लिए है, हम इसे उसी के अनुसार नाम देते हैं: Validate_SKU

    महत्वपूर्ण नोट! सूत्र को परिभाषित करते समय, कृपया दोबारा जांच लें कि पहला तर्क वर्तमान में चयनित सेल को संदर्भित करता है, अन्यथा सूत्र काम नहीं करेगा। उदाहरण के लिए, यदि सेल A1 को शीट पर चुना गया है, तो A1 को पहले तर्क में रखें (हमारी सिफारिशों के अनुसार); यदि B2 चुना गया है, तो पहले तर्क के लिए B2 का उपयोग करें, और इसलिए एक। जब तक यह वर्तमान में चयनित सेल से मेल खाता है, तब तक यह वास्तव में मायने नहीं रखता कि आप किस विशेष संदर्भ का उपयोग करते हैं।

    चरण-दर-चरण के लिएनिर्देश, कृपया देखें कि एक्सेल में नामांकित सूत्र कैसे बनाया जाता है।

    3। डेटा वैलिडेशन सेट अप करें

    चेक किए जाने वाले पहले सेल का चयन करें (हमारे मामले में A5) और नामित सूत्र के आधार पर एक कस्टम डेटा वैलिडेशन नियम बनाएं। इसके लिए, निम्न कार्य करें:

    1. डेटा टैब > डेटा सत्यापन क्लिक करें।
    2. अनुमति दें<2 में> ड्रॉप-डाउन सूची में, कस्टम चुनें।
    3. संबंधित बॉक्स में नीचे दिए गए सूत्र को दर्ज करें।

      =Validate_SKU

    4. रिक्त को अनदेखा करें विकल्प को अचयनित करें, अन्यथा आपका नियम काम नहीं करेगा।

    वैकल्पिक रूप से, आप टाइप कर सकते हैं सेल में अमान्य डेटा दर्ज किए जाने पर प्रदर्शित होने वाला कस्टम त्रुटि संदेश।

    यदि आपको लगता है कि आपको विस्तृत चरणों की आवश्यकता है, तो आप यहां जाएं: एक्सेल में कस्टम डेटा सत्यापन कैसे सेट करें।

    4। डेटा सत्यापन को और अधिक सेल में कॉपी करें

    सत्यापन सेटिंग को अधिक सेल में कॉपी करने के लिए, आपको यह करना होगा:

    1. डेटा सत्यापन वाले सेल का चयन करें और इसके लिए Ctrl + C दबाएं इसे कॉपी करें।
    2. उन अन्य सेल का चयन करें जिन्हें आप सत्यापित करना चाहते हैं, उन्हें राइट-क्लिक करें, विशेष पेस्ट करें पर क्लिक करें, और मान्यकरण विकल्प चुनें।
    3. ओके क्लिक करें।

    डेटा सत्यापन की प्रतिलिपि कैसे करें में अधिक जानकारी प्राप्त की जा सकती है।

    अब, हर बार जब कोई किसी मान्य सेल में अमान्य SKU दर्ज करने का प्रयास करता है, तो निम्न चेतावनी संदेश दिखाई देगा:

    रेगेक्स के साथ ईमेल सत्यापन

    ईमेल सत्यापन करने के लिए, आप प्रारंभ करेंईमेल पते से मेल खाने वाली रेगुलर एक्सप्रेशन लिखने के साथ।

    पैटर्न : ^[\w\.\-]+@[A-Za-z0-9]+[A-Za -z0-9\.\-]*[A-Za-z0-9]+\.[A-Za-z]{2,24}$

    सिंटैक्स की विस्तृत व्याख्या के लिए, कृपया मान्य ईमेल पतों के मिलान के लिए Regex देखें।

    और अब, पहले से परिचित चरणों का पालन करके सत्यापन मानदंड निर्दिष्ट करें:

    1. B2 में उपरोक्त रेगेक्स दर्ज करें।
    2. सेल A1 का चयन करें और Validate_Email नामक एक नाम परिभाषित करें जो कि संदर्भित करता है:

      =RegExpMatch(Sheet1!A1, Sheet1!$B$2)

    3. सेल B5 के लिए, नीचे दिए गए सूत्र का उपयोग करके कस्टम डेटा सत्यापन लागू करें। यह आवश्यक है कि खाली पर ध्यान न दें विकल्प अचयनित होना चाहिए।

      =Validate_Email

      इसके अतिरिक्त, आप उपयोगकर्ता को मान्य ईमेल पता दर्ज करने के लिए संकेत देने वाला एक कस्टम त्रुटि संदेश कॉन्फ़िगर कर सकते हैं।

    4. नियम को नीचे दिए गए सेल में कॉपी करें।

    अगर एक मान्य सेल में दर्ज किया गया ईमेल पता रेगेक्स पैटर्न से मेल नहीं खाता है, तो निम्नलिखित अलर्ट होगा पॉप अप करें:

    रेगुलर एक्सप्रेशन का उपयोग करके पासवर्ड मान्य करना

    पासवर्ड सत्यापन के लिए रेगेक्स का उपयोग करते समय, सबसे पहले यह तय करना होगा कि आपके रेगुलर एक्सप्रेशन को वास्तव में क्या देखना चाहिए। यहां कुछ उदाहरण दिए गए हैं जो आपको सही रास्ते पर ले जा सकते हैं।

    एक पासवर्ड कम से कम 6 वर्ण लंबा होना चाहिए और इसमें केवल अक्षर (अपरकेस या लोअरकेस) और अंक हो सकते हैं:

    पैटर्न : ^[A-Za-z0-9]{6,}$

    एक पासवर्ड कम से कम 6 अक्षरों का होना चाहिए और इसमें कम से कम एक अक्षर औरएक अंक:

    पैटर्न : ^(?=.*[A-Za-z])(?=.*\d)[A-Za-z\d]{6 ,}$

    एक पासवर्ड कम से कम 6 वर्ण लंबा होना चाहिए और इसमें कम से कम एक अपरकेस अक्षर, एक लोअरकेस अक्षर और एक अंक शामिल होना चाहिए:

    पैटर्न : ^(?= .*[A-Z])(?=.*[a-z])(?=.*\d)[A-Za-z\d]{6,}$

    एक पासवर्ड कम से कम 6 अक्षरों का होना चाहिए लंबा और कम से कम एक अक्षर, एक अंक और एक विशेष वर्ण शामिल करें:

    पैटर्न : ^(?=.*[A-Za-z])(?=.*\d )(?=.*[@$!%*#?&_-])[A-Za-z\d@$!%*#?&_-]{6,}$

    स्थापित पैटर्न के साथ, आप डेटा सत्यापन सेट अप करने के लिए आगे बढ़ सकते हैं:

    1. C2 में अपना पासवर्ड रेगेक्स दर्ज करें।
    2. सेल A1 का चयन करें और नामक एक नामित सूत्र बनाएं Validate_Password :

      =RegExpMatch(Sheet1!A1, Sheet1!$C$2)

    3. सेल C5 के लिए, नीचे दिए गए फ़ॉर्मूले से एक कस्टम सत्यापन नियम बनाएं। रिक्त को अनदेखा करें चेक बॉक्स को अचयनित करना याद रखें।

      =Validate_Password

    4. जितने चाहें उतने सेल में नियम कॉपी करें।

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

    रेगेक्स डेटा सत्यापन काम नहीं कर रहा है

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

    RegExpMatch फ़ंक्शन अनुपलब्ध

    डेटा सत्यापन लागू करने से पहले, अपनी कार्यपुस्तिका में RegExpMatch फ़ंक्शन का कोड सम्मिलित करना सुनिश्चित करें।

    गलत नियमितअभिव्यक्ति

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

    डेटा सत्यापन विफलता का एक बहुत ही सामान्य कारण एक गलत सेल का संदर्भ देने वाला एक रेगेक्स नाम का सूत्र है। सभी उदाहरणों में, हमने A1 को संदर्भित करते हुए एक सूत्र को परिभाषित करने की सिफारिश की:

    =RegExpMatch(A1, regex)

    यह केवल तभी काम करता है जब सेल A1 सक्रिय है जब एक नाम और <15 को परिभाषित किया जाता है>सापेक्ष संदर्भ (बिना $ चिह्न के) का उपयोग किया जाता है।

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

    स्क्रीनशॉट मेंनीचे, सेल A7 चुना गया है, जिसका अर्थ है कि नामांकित सूत्र में पहले तर्क में A7 होना चाहिए। दूसरा तर्क ($A$2) रेगेक्स को संदर्भित करता है - यह संदर्भ स्थिर रहने वाला माना जाता है, इसलिए इसे $ चिन्ह के साथ बंद कर दिया जाता है।

    खाली विकल्प को अनदेखा करें

    कस्टम डेटा सत्यापन नियम सेट करते समय, रिक्त को अनदेखा करें चेक बॉक्स को अचयनित करना महत्वपूर्ण है। अन्यथा, निम्नलिखित कारणों से नियम काम नहीं करेगा:

    यदि कोई मिलान नहीं मिलता है, तो RegExpMatch फ़ंक्शन FALSE लौटाता है। रिक्त को अनदेखा करें विकल्प चुने जाने पर, FALSE रिक्त के बराबर होता है और इसे अनदेखा कर दिया जाता है।

    एक वैकल्पिक समाधान स्पष्ट रूप से कह रहा है कि सूत्र TRUE लौटाना चाहिए:

    =RegExpMatch(…)=TRUE

    रेगुलर एक्सप्रेशंस का उपयोग करके एक्सेल में डेटा सत्यापन कैसे करें। मैं आपको पढ़ने के लिए धन्यवाद देता हूं और अगले सप्ताह आपको हमारे ब्लॉग पर देखने के लिए उत्सुक हूं!

    डाउनलोड के लिए अभ्यास कार्यपुस्तिका

    Regex डेटा सत्यापन उदाहरण (.xlsm फ़ाइल)

    <3

    माइकल ब्राउन सॉफ्टवेयर टूल्स का उपयोग करके जटिल प्रक्रियाओं को सरल बनाने के जुनून के साथ एक समर्पित प्रौद्योगिकी उत्साही है। टेक उद्योग में एक दशक से अधिक के अनुभव के साथ, उन्होंने माइक्रोसॉफ्ट एक्सेल और आउटलुक के साथ-साथ गूगल शीट्स और डॉक्स में अपने कौशल को निखारा है। माइकल का ब्लॉग अपने ज्ञान और विशेषज्ञता को दूसरों के साथ साझा करने के लिए समर्पित है, उत्पादकता और दक्षता में सुधार के लिए आसान-से-अनुसरण युक्तियाँ और ट्यूटोरियल प्रदान करता है। चाहे आप एक अनुभवी पेशेवर हों या नौसिखिए, माइकल का ब्लॉग इन आवश्यक सॉफ़्टवेयर उपकरणों से अधिकाधिक लाभ उठाने के लिए मूल्यवान अंतर्दृष्टि और व्यावहारिक सलाह प्रदान करता है।