VBA - त्वरित गाइड

VBA के लिए खड़ा है Visual Bके लिए asic AMicrosoft से एक इवेंट-संचालित प्रोग्रामिंग भाषा है जो अब मुख्य रूप से MSExcel, MS-Word और MS-Access जैसे Microsoft कार्यालय अनुप्रयोगों के साथ उपयोग की जाती है।

यह उन अनुप्रयोगों की क्षमताओं को बढ़ाने के लिए अनुकूलित अनुप्रयोगों और समाधानों का निर्माण करने में तकनीकी मदद करता है। इस सुविधा का लाभ यह है कि आपके पास हमारे पीसी पर दृश्य मूल स्थापित नहीं है, हालांकि, कार्यालय स्थापित करने से उद्देश्य प्राप्त करने में मदद मिलेगी।

आप सभी Office संस्करणों में VBA का उपयोग कर सकते हैं, MS-Office 97 से MS-Office 2013 के लिए और उपलब्ध नवीनतम संस्करणों में से किसी के साथ भी। VBA में, Excel VBA सबसे लोकप्रिय है। VBA का उपयोग करने का लाभ यह है कि आप रैखिक प्रोग्रामिंग का उपयोग करके MS Excel में बहुत शक्तिशाली उपकरण बना सकते हैं।

VBA का अनुप्रयोग

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

उदाहरण के लिए, एक्सेल के बिल्ट-इन फॉर्मूलों का उपयोग करके ऋण की मासिक चुकौती की गणना करना बहुत कठिन है। बल्कि, ऐसी गणना के लिए एक VBA प्रोग्राम करना आसान है।

VBA संपादक तक पहुँचना

एक्सेल विंडो में, "ALT + F11" दबाएं। एक VBA विंडो खुलती है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

इस अध्याय में, आप सीखेंगे कि एक स्टेप बाई स्टेप तरीके से सरल मैक्रो कैसे लिखें।

Step 1- सबसे पहले, एक्सेल 20XX में 'डेवलपर' मेनू को सक्षम करें। ऐसा करने के लिए, फ़ाइल → विकल्प पर क्लिक करें।

Step 2- रिबन 'टैब को कस्टमाइज़ करें और' डेवलपर 'पर क्लिक करें। ओके पर क्लिक करें'।

Step 3 - मेन्यू बार में 'डेवलपर' रिबन दिखाई देता है।

Step 4 - VBA एडिटर को खोलने के लिए 'Visual Basic' बटन पर क्लिक करें।

Step 5- एक बटन जोड़कर स्क्रिप्टिंग शुरू करें। सम्मिलित करें पर क्लिक करें → बटन का चयन करें।

Step 6 - राइट-क्लिक करें और 'गुण' चुनें।

Step 7 - नाम और कैप्शन को संपादित करें जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 8 - अब बटन पर डबल-क्लिक करें और उप-प्रक्रिया की रूपरेखा निम्न स्क्रीनशॉट में दिखाए अनुसार प्रदर्शित की जाएगी।

Step 9 - बस एक संदेश जोड़कर कोडिंग शुरू करें।

Private Sub say_helloworld_Click()
   MsgBox "Hi"
End Sub

Step 10- उप-प्रक्रिया को निष्पादित करने के लिए बटन पर क्लिक करें। उप-प्रक्रिया का आउटपुट निम्न स्क्रीनशॉट में दिखाया गया है। सुनिश्चित करें कि आपके पास डिज़ाइन मोड चालू है। यदि यह चालू नहीं है तो बस इसे चालू करने के लिए इसे क्लिक करें।

Note - आगे के अध्यायों में, हम एक सरल बटन का उपयोग करके प्रदर्शित करेंगे, जैसा कि चरण # 1 से 10 तक समझाया गया है। इसलिए, इस अध्याय को अच्छी तरह से समझना महत्वपूर्ण है।

इस अध्याय में, आप अपने आप को आमतौर पर इस्तेमाल किए जाने वाले एक्सेल VBA शब्दावली से परिचित कराएँगे। इन शब्दावली का उपयोग आगे के मॉड्यूल में किया जाएगा, इसलिए इनमें से प्रत्येक को समझना महत्वपूर्ण है।

मॉड्यूल

मॉड्यूल वह क्षेत्र है जहां कोड लिखा जाता है। यह एक नई कार्यपुस्तिका है, इसलिए कोई मॉड्यूल नहीं हैं।

एक मॉड्यूल डालने के लिए, सम्मिलित करने के लिए नेविगेट करें → मॉड्यूल। एक बार एक मॉड्यूल डाला जाता है 'मॉड्यूल 1' बनाया जाता है।

मॉड्यूल के भीतर, हम VBA कोड लिख सकते हैं और कोड एक प्रक्रिया के भीतर लिखा जाता है। एक प्रक्रिया / उप प्रक्रिया वीबीए बयानों की एक श्रृंखला होती है, जिसमें निर्देश दिया जाता है कि क्या करना है।

प्रक्रिया

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

प्रक्रिया के दो मुख्य प्रकार उप और कार्य हैं।

समारोह

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

इनबिल्ट फ़ंक्शंस के अलावा, वीबीए उपयोगकर्ता-परिभाषित कार्यों को भी लिखने की अनुमति देता है और बीच में बयान लिखे जाते हैं Function तथा End Function

उप-प्रक्रियाओं

उप-प्रक्रियाएं फ़ंक्शन के समान काम करती हैं। जबकि उप-प्रक्रियाएँ मान वापस नहीं करती हैं, फ़ंक्शन मान वापस कर सकते हैं या नहीं भी कर सकते हैं। उप प्रक्रियाओं को बिना कॉल कीवर्ड के कहा जा सकता है। उप प्रक्रियाओं को हमेशा के भीतर संलग्न किया जाता हैSub तथा End Sub बयान।

टिप्पणियों का उपयोग प्रोग्राम लॉजिक और उपयोगकर्ता जानकारी को दस्तावेज करने के लिए किया जाता है जिसके साथ अन्य प्रोग्रामर भविष्य में समान कोड पर काम कर सकते हैं।

इसमें द्वारा विकसित की गई जानकारी शामिल है, इसके द्वारा संशोधित, और इसमें शामिल तर्क भी शामिल हो सकते हैं। निष्पादन के दौरान टिप्पणियों को दुभाषिया द्वारा अनदेखा किया जाता है।

VBA में टिप्पणियाँ दो विधियों द्वारा निरूपित की जाती हैं।

  • एकल उद्धरण (') से शुरू होने वाले किसी भी कथन को टिप्पणी के रूप में माना जाता है। निम्नलिखित एक उदाहरण है।

' This Script is invoked after successful login 
' Written by : TutorialsPoint 
' Return Value : True / False
  • कोई भी कथन जो "REM" कीवर्ड से शुरू होता है। निम्नलिखित एक उदाहरण है।

REM This Script is written to Validate the Entered Input 
REM Modified by  : Tutorials point/user2

MsgBox function एक संदेश बॉक्स प्रदर्शित करता है और उपयोगकर्ता द्वारा बटन क्लिक करने की प्रतीक्षा करता है और फिर उपयोगकर्ता द्वारा क्लिक किए गए बटन के आधार पर एक क्रिया की जाती है।

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

MsgBox(prompt[,buttons][,title][,helpfile,context])

पैरामीटर विवरण

  • Prompt- एक आवश्यक पैरामीटर। एक स्ट्रिंग जो संवाद बॉक्स में एक संदेश के रूप में प्रदर्शित होती है। शीघ्र की अधिकतम लंबाई लगभग 1024 वर्ण है। यदि संदेश एक पंक्ति से अधिक तक फैली हुई है, तो प्रत्येक पंक्ति के बीच एक गाड़ी वापसी चरित्र (Chr (13)) या लाइनफ़ीड वर्ण (Chr (10)) का उपयोग करके लाइनों को अलग किया जा सकता है।

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

  • Title- एक वैकल्पिक पैरामीटर। संवाद बॉक्स के शीर्षक पट्टी में प्रदर्शित स्ट्रिंग अभिव्यक्ति। यदि शीर्षक खाली छोड़ दिया जाता है, तो एप्लिकेशन का नाम शीर्षक बार में रखा जाता है।

  • Helpfile- एक वैकल्पिक पैरामीटर। स्ट्रिंग अभिव्यक्ति जो संवाद बॉक्स के लिए संदर्भ-संवेदनशील मदद प्रदान करने के लिए उपयोग करने के लिए मदद फ़ाइल की पहचान करती है।

  • Context- एक वैकल्पिक पैरामीटर। एक संख्यात्मक अभिव्यक्ति जो मदद लेखक द्वारा उपयुक्त सहायता विषय को सौंपे गए मदद संदर्भ संख्या की पहचान करती है। यदि संदर्भ प्रदान किया जाता है, तो हेल्पफाइल भी प्रदान किया जाना चाहिए।

Buttons पैरामीटर निम्नलिखित में से कोई भी मान ले सकता है -

  • 0 vbOKOnly - केवल ओके बटन प्रदर्शित करता है।

  • 1 vbOKCancel - ठीक दिखाता है और रद्द करें बटन।

  • 2 vbAbortRetryIgnore - एबोर्ट, रिट्री और इग्नोर बटन प्रदर्शित करता है।

  • 3 vbYesNoCancel - हाँ, नहीं, और रद्द करें बटन प्रदर्शित करता है।

  • 4 vbYesNo - हां और नहीं बटन प्रदर्शित करता है।

  • 5 vbRetryCancel - रिट्रीट और रद्द बटन प्रदर्शित करता है।

  • 16 vbCritical - महत्वपूर्ण संदेश आइकन प्रदर्शित करता है।

  • 32 vbQuestion - चेतावनी क्वेरी आइकन प्रदर्शित करता है।

  • 48 vbExclamation - चेतावनी संदेश आइकन प्रदर्शित करता है।

  • 64 vbInformation - सूचना संदेश आइकन प्रदर्शित करता है।

  • 0 vbDefaultButton1 - पहला बटन डिफ़ॉल्ट है।

  • 256 vbDefaultButton2 - दूसरा बटन डिफ़ॉल्ट है।

  • 512 vbDefaultButton3 - तीसरा बटन डिफ़ॉल्ट है।

  • 768 vbDefaultButton4 - चौथा बटन डिफ़ॉल्ट है।

  • 0 vbApplicationModal एप्लिकेशन मोडल - वर्तमान एप्लिकेशन तब तक काम नहीं करेगा जब तक उपयोगकर्ता संदेश बॉक्स पर प्रतिक्रिया नहीं देगा।

  • 4096 vbSystemModal सिस्टम मोडल - उपयोगकर्ता के संदेश बॉक्स पर प्रतिक्रिया देने तक सभी एप्लिकेशन काम नहीं करेंगे।

उपरोक्त मान तार्किक रूप से चार समूहों में विभाजित हैं: first group(0 से 5) संदेश बॉक्स में प्रदर्शित होने वाले बटन को इंगित करता है। second group (16, 32, 48, 64) प्रदर्शित की जाने वाली आइकन की शैली का वर्णन करता है, third group (0, 256, 512, 768) इंगित करता है कि कौन सा बटन डिफ़ॉल्ट होना चाहिए, और fourth group (०, ४० ९ ६) मैसेज बॉक्स की मॉड्युलिटी निर्धारित करता है।

वापसी मान

MsgBox फ़ंक्शन निम्न मानों में से एक को वापस कर सकता है जिसका उपयोग उपयोगकर्ता द्वारा संदेश बॉक्स में क्लिक किए गए बटन को पहचानने के लिए किया जा सकता है।

  • 1 - vbOK - ठीक पर क्लिक किया गया था
  • 2 - vbCancel - रद्द किया गया
  • 3 - vbAbort - एबॉर्ट पर क्लिक किया गया
  • 4 - vbRetry - रिट्री पर क्लिक किया गया
  • 5 - vbIgnore - इग्नोर पर क्लिक किया गया
  • 6 - vbYes - हां क्लिक किया गया था
  • 7 - vbNo - क्लिक नहीं किया गया था

उदाहरण

Function MessageBox_Demo() 
   'Message Box with just prompt message 
   MsgBox("Welcome")     
   
   'Message Box with title, yes no and cancel Butttons  
   int a = MsgBox("Do you like blue color?",3,"Choose options") 
   ' Assume that you press No Button  
   msgbox ("The Value of a is " & a) 
End Function

उत्पादन

Step 1 - उपरोक्त फ़ंक्शन VBA विंडो पर "रन" बटन पर क्लिक करके या एक्सेल वर्कशीट से फ़ंक्शन को कॉल करके निष्पादित किया जा सकता है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 2 - एक सरल संदेश बॉक्स एक संदेश "वेलकम" और एक "ओके" बटन के साथ प्रदर्शित किया जाता है

Step 3 - ओके करने के बाद क्लिक करें, फिर भी एक अन्य डायलॉग बॉक्स "हां, नहीं, और रद्द करें" बटन के साथ एक संदेश के साथ प्रदर्शित होता है।

Step 4- 'नहीं' बटन पर क्लिक करने के बाद, उस बटन (7) का मान एक पूर्णांक के रूप में संग्रहीत किया जाता है और उपयोगकर्ता को संदेश बॉक्स के रूप में प्रदर्शित किया जाता है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है। इस मान का उपयोग करते हुए, यह समझा जा सकता है कि उपयोगकर्ता ने किस बटन पर क्लिक किया है।

InputBox functionउपयोगकर्ताओं को मूल्यों को दर्ज करने का संकेत देता है। मान दर्ज करने के बाद, यदि उपयोगकर्ता ठीक बटन पर क्लिक करता है या कीबोर्ड पर ENTER दबाता है, तो इनपुट बॉक्स फ़ंक्शन पाठ बॉक्स में पाठ वापस कर देगा। यदि उपयोगकर्ता रद्द बटन पर क्लिक करता है, तो फ़ंक्शन एक खाली स्ट्रिंग ("") वापस करेगा।

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

InputBox(prompt[,title][,default][,xpos][,ypos][,helpfile,context])

पैरामीटर विवरण

  • Prompt- एक आवश्यक पैरामीटर। एक स्ट्रिंग जो संवाद बॉक्स में एक संदेश के रूप में प्रदर्शित होती है। शीघ्र की अधिकतम लंबाई लगभग 1024 वर्ण है। यदि संदेश एक पंक्ति से अधिक तक फैली हुई है, तो प्रत्येक पंक्ति के बीच एक गाड़ी वापसी चरित्र (Chr (13)) या लाइनफ़ीड वर्ण (Chr (10)) का उपयोग करके लाइनों को अलग किया जा सकता है।

  • Title- एक वैकल्पिक पैरामीटर। संवाद बॉक्स के शीर्षक पट्टी में प्रदर्शित स्ट्रिंग अभिव्यक्ति। यदि शीर्षक खाली छोड़ दिया जाता है, तो एप्लिकेशन का नाम शीर्षक बार में रखा जाता है।

  • Default- एक वैकल्पिक पैरामीटर। पाठ बॉक्स में एक डिफ़ॉल्ट पाठ जिसे उपयोगकर्ता प्रदर्शित करना चाहेगा।

  • XPos- एक वैकल्पिक पैरामीटर। की स्थितिXअक्ष क्षैतिज रूप से स्क्रीन के बाईं ओर से शीघ्र दूरी का प्रतिनिधित्व करता है। यदि खाली छोड़ दिया जाता है, तो इनपुट बॉक्स क्षैतिज रूप से केंद्रित होता है।

  • YPos- एक वैकल्पिक पैरामीटर। की स्थितिYअक्ष स्क्रीन के बाईं ओर से शीघ्र दूरी का प्रतिनिधित्व करता है। यदि खाली छोड़ दिया जाता है, तो इनपुट बॉक्स लंबवत केंद्रित होता है।

  • Helpfile- एक वैकल्पिक पैरामीटर। एक स्ट्रिंग अभिव्यक्ति, जो संवाद बॉक्स के लिए संदर्भ-संवेदनशील सहायता प्रदान करने के लिए उपयोग की जाने वाली हेल्पफाइल की पहचान करती है।

  • context- एक वैकल्पिक पैरामीटर। एक संख्यात्मक अभिव्यक्ति जो मदद लेखक द्वारा उपयुक्त सहायता विषय को सौंपे गए मदद संदर्भ संख्या की पहचान करती है। यदि संदर्भ प्रदान किया जाता है, तो हेल्पफाइल भी प्रदान किया जाना चाहिए।

उदाहरण

आइए हम दो इनपुट बॉक्स (लंबाई के लिए एक और चौड़ाई के लिए एक) की मदद से उपयोगकर्ता से मूल्यों को प्राप्त करके आयत के क्षेत्र की गणना करें।

Function findArea() 
   Dim Length As Double 
   Dim Width As Double 
   
   Length = InputBox("Enter Length ", "Enter a Number") 
   Width = InputBox("Enter Width", "Enter a Number") 
   findArea = Length * Width 
End Function

उत्पादन

Step 1 - उसी को निष्पादित करने के लिए, फ़ंक्शन नाम का उपयोग करके कॉल करें और निम्न स्क्रीनशॉट में दिखाए अनुसार Enter दबाएं।

Step 2- निष्पादन पर, पहला इनपुट बॉक्स (लंबाई) प्रदर्शित होता है। इनपुट बॉक्स में एक मान दर्ज करें।

Step 3 - पहले मूल्य में प्रवेश करने के बाद, दूसरा इनपुट बॉक्स (चौड़ाई) प्रदर्शित किया जाता है।

Step 4- दूसरा नंबर डालने पर ओके बटन पर क्लिक करें। क्षेत्र को निम्न स्क्रीनशॉट में दिखाया गया है।

Variableएक नामित मेमोरी स्थान है जिसका उपयोग स्क्रिप्ट निष्पादन के दौरान एक मूल्य को रखने के लिए किया जा सकता है। चर का नामकरण करने के लिए बुनियादी नियम निम्नलिखित हैं।

  • आपको पहले अक्षर के रूप में एक पत्र का उपयोग करना चाहिए।

  • आप नाम में स्थान, अवधि (।), विस्मयादिबोधक चिह्न (!), या वर्ण @, &, $, # का उपयोग नहीं कर सकते।

  • नाम लंबाई में 255 वर्णों से अधिक नहीं हो सकता।

  • आप चर नाम के रूप में Visual Basic आरक्षित कीवर्ड का उपयोग नहीं कर सकते।

Syntax

VBA में, आपको उन्हें उपयोग करने से पहले चर घोषित करना होगा।

Dim <<variable_name>> As <<variable_type>>

जानकारी का प्रकार

कई VBA डेटा प्रकार हैं, जिन्हें दो मुख्य श्रेणियों में विभाजित किया जा सकता है, अर्थात् संख्यात्मक और गैर-संख्यात्मक डेटा प्रकार।

संख्यात्मक डेटा प्रकार

निम्न तालिका संख्यात्मक डेटा प्रकार और मानों की अनुमत सीमा प्रदर्शित करती है।

प्रकार मूल्यों की श्रृंखला
बाइट 0 से 255 रु
पूर्णांक -32,768 से 32,767
लंबा -2,147,483,648 से 2,147,483,648
एक

नकारात्मक मूल्यों के लिए -3.402823E + 38 से -1.401298E-45

सकारात्मक मूल्यों के लिए 1.401298E-45 से 3.402823E + 38।

दोहरा

नकारात्मक मूल्यों के लिए -1.79769313486232e + 308 से -4.94065645841247E-324

सकारात्मक मूल्यों के लिए 4.94065645841247E-324 से 1.79769313486232e + 308।

मुद्रा -922,337,203,685,477.5808 से 922,337,203,685,477.5807
दशमलव

अगर कोई दशमलव उपयोग नहीं होता है तो +/- 79,228,162,514,264,337,593,543,950,335

+/- 7.9228162514264337593543950335 (28 दशमलव स्थान)।

गैर-संख्यात्मक डेटा प्रकार

निम्न तालिका गैर-संख्यात्मक डेटा प्रकारों और अनुमत मानों को प्रदर्शित करती है।

प्रकार मूल्यों की श्रृंखला
स्ट्रिंग (निश्चित लंबाई) 1 से 65,400 वर्ण
स्ट्रिंग (चर लंबाई) 0 से 2 बिलियन अक्षर
दिनांक 1 जनवरी, 100 से 31 दिसंबर, 9999
बूलियन सही या गलत
वस्तु कोई एम्बेडेड ऑब्जेक्ट
भिन्न (संख्यात्मक) किसी भी मूल्य के रूप में डबल के रूप में बड़े
भिन्न (पाठ) चर-लंबाई स्ट्रिंग के रूप में भी

Example

हम एक बटन बनाते हैं और चर के उपयोग को प्रदर्शित करने के लिए इसे 'Variables_demo' नाम देते हैं।

Private Sub say_helloworld_Click()
   Dim password As String
   password = "Admin#1"

   Dim num As Integer
   num = 1234

   Dim BirthDay As Date
   BirthDay = DateValue("30 / 10 / 2020")

   MsgBox "Passowrd is " & password & Chr(10) & "Value of num is " &
      num & Chr(10) & "Value of Birthday is " & BirthDay
End Sub

Output

स्क्रिप्ट निष्पादित करने पर, आउटपुट निम्न स्क्रीनशॉट में दिखाया जाएगा।

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

किसी स्थिरांक का नाम रखने के नियम निम्नलिखित हैं।

  • आपको पहले अक्षर के रूप में एक पत्र का उपयोग करना चाहिए।

  • आप नाम में स्थान, अवधि (।), विस्मयादिबोधक चिह्न (!), या वर्ण @, &, $, # का उपयोग नहीं कर सकते।

  • नाम लंबाई में 255 वर्णों से अधिक नहीं हो सकता।

  • आप चर नाम के रूप में Visual Basic आरक्षित कीवर्ड का उपयोग नहीं कर सकते।

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

VBA में, हमें घोषित कॉन्स्टेंट के लिए एक मान असाइन करने की आवश्यकता है। यदि हम स्थिरांक का मान बदलने का प्रयास करते हैं, तो एक त्रुटि है।

Const <<constant_name>> As <<constant_type>> = <<constant_value>>

उदाहरण

हमें एक बटन "कॉन्स्टेंट_डेमो" बनाने के लिए प्रदर्शित करें कि कैसे स्थिरांक के साथ काम करना है।

Private Sub Constant_demo_Click() 
   Const MyInteger As Integer = 42 
   Const myDate As Date = #2/2/2020# 
   Const myDay As String = "Sunday" 
   
   MsgBox "Integer is " & MyInteger & Chr(10) & "myDate is " 
      & myDate & Chr(10) & "myDay is " & myDay  
End Sub

उत्पादन

स्क्रिप्ट निष्पादित करने पर, आउटपुट निम्न स्क्रीनशॉट में दिखाया गया है।

एक Operator एक सरल अभिव्यक्ति का उपयोग करके परिभाषित किया जा सकता है - 4 + 5 9 के बराबर है। यहां, 4 और 5 कहा जाता है operands और + कहा जाता है operator। VBA ऑपरेटरों के प्रकार का समर्थन करता है -

  • अंकगणितीय आपरेटर
  • तुलना संचालक
  • तार्किक (या संबंधपरक) संचालक
  • कॉनटेनटेशन ऑपरेटर्स

अरिथमेटिक ऑपरेटर्स

निम्नलिखित अंकगणित ऑपरेटरों को VBA द्वारा समर्थित किया जाता है।

चर A मान लें 5 और चर B 10 है, तो -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
+ दो ऑपरेंड जोड़ता है A + B 15 देगा
- पहले से दूसरे ऑपरेंड को घटाता है A - B -5 देगा
* दोनों ऑपरेंड को गुणा करता है A * B 50 देगा
/ भाजक को अंश से विभाजित करता है B / A 2 देगा
% मापांक ऑपरेटर और पूर्णांक विभाजन के बाद शेष ब% ए द 0 दे खेंगे
^ यययय ययय ययय ययययय B ^ A 100000 देगा

तुलना संचालक

VBA द्वारा समर्थित तुलनात्मक ऑपरेटर निम्नलिखित हैं।

चर ए मान लें 10 और चर बी 20 रखती है, तो -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
= जाँच करता है कि दो ऑपरेंड का मान बराबर है या नहीं। यदि हाँ, तो यह शर्त सही है। (ए = बी) गलत है।
<> जाँच करता है कि दो ऑपरेंड का मान बराबर है या नहीं। यदि मान नहीं के बराबर हैं, तो स्थिति सत्य है। (ए <> बी) सच है।
> जाँचता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से अधिक है। यदि हाँ, तो यह शर्त सही है। (ए> बी) गलत है।
< जांचता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से कम है। यदि हाँ, तो यह शर्त सही है। (ए <बी) सच है।
> = यह जाँचता है कि बाएँ ऑपरेंड का मान सही ऑपरेंड के मान से अधिक या उसके बराबर है या नहीं। यदि हाँ, तो यह शर्त सही है। (ए> = बी) गलत है।
<= यह जाँचता है कि बाएं ऑपरेंड का मान सही ऑपरेंड के मान से कम या बराबर है। यदि हाँ, तो यह शर्त सही है। (ए <= बी) सच है।

लॉजिकल ऑपरेटर्स

निम्नलिखित तार्किक ऑपरेटरों को VBA द्वारा समर्थित किया जाता है।

चर A मानें 10 और चर B धारण 0, तब -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
तथा जिसे लॉजिकल एंड ऑपरेटर कहा जाता है। यदि दोनों स्थितियाँ सत्य हैं, तो अभिव्यक्ति सत्य है। एक <> 0 और b <> 0 गलत है।
या जिसे लॉजिकल या ऑपरेटर कहा जाता है। यदि दोनों में से कोई भी स्थिति सत्य है, तो स्थिति सत्य है। <> 0 या b <> 0 सत्य है।
नहीं जिसे लॉजिकल नॉट ऑपरेटर कहा जाता है। अपने ऑपरेंड की तार्किक स्थिति को उलट देता था। यदि कोई शर्त सही है, तो तार्किक संचालक गलत नहीं करेगा। नहीं (<> 0 या b <> 0) गलत है।
XOR जिसे लॉजिकल एक्सक्लूसिव कहा जाता है। यह NOT और OR ऑपरेटर का संयोजन है। यदि एक, और केवल एक, भाव सही होने का मूल्यांकन करता है, तो परिणाम सत्य है। (एक <> 0 XOR b <> 0) सत्य है।

कॉनटेनटेशन ऑपरेटर्स

अनुवर्ती संचालनों को VBA द्वारा समर्थित किया जाता है।

चर A मान लें 5 और चर B 10 धारण करता है -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
+ परिवर्तनीय के रूप में दो मान जोड़ता है। मान न्यूमेरिक हैं A + B 15 देगा
और दो मूल्यों को सम्‍मिलित करता है A & B 510 देगा

चर A = "Microsoft" और चर B = "VBScript" मान लें, फिर -

ऑपरेटर विवरण उदाहरण
+ दो मूल्यों को सम्‍मिलित करता है A + B MicrosoftVBScript देगा
और दो मूल्यों को सम्‍मिलित करता है A & B MicrosoftVBScript देगा

Note- कॉन्टैकटेशन ऑपरेटर्स का इस्तेमाल नंबर और स्ट्रिंग्स दोनों के लिए किया जा सकता है। आउटपुट संदर्भ पर निर्भर करता है, यदि चर संख्यात्मक मान या स्ट्रिंग मान रखते हैं।

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

अधिकांश प्रोग्रामिंग भाषाओं में पाया जाने वाला एक विशिष्ट निर्णय लेने की संरचना का सामान्य रूप निम्नलिखित है।

VBA निर्णय लेने के निम्नलिखित प्रकार प्रदान करता है। उनके विवरण की जांच करने के लिए निम्नलिखित लिंक पर क्लिक करें।

अनु क्रमांक। विवरण और विवरण
1 अगर बयान

एक if एक बूलियन अभिव्यक्ति के कथन में एक या अधिक कथन होते हैं।

2 if..else स्टेटमेंट

एक if elseएक बूलियन अभिव्यक्ति के कथन में एक या अधिक कथन होते हैं। यदि स्थिति सत्य है, तो कथन के तहतIfबयान निष्पादित किए जाते हैं। अगर हालत झूठी है,Else स्क्रिप्ट का एक भाग निष्पादित किया जाता है।

3 अगर ... और तो और .. बयान

एक if एक या अधिक के बाद बयान ElseIf बयान, कि बूलियन अभिव्यक्ति के होते हैं और फिर एक वैकल्पिक द्वारा पीछा किया else statement, जो तब निष्पादित होता है जब सारी स्थिति झूठी हो जाती है।

4 बयान दिया तो नेस्टेड

एक if या elseif दूसरे के अंदर बयान if या elseif कथन (नों)।

5 स्विच स्टेटमेंट

switch कथन मानों की सूची के विरुद्ध समानता के लिए एक चर का परीक्षण करने की अनुमति देता है।

ऐसी स्थिति हो सकती है जब आपको कई बार कोड के ब्लॉक को निष्पादित करने की आवश्यकता होती है। सामान्य तौर पर, बयानों को क्रमिक रूप से निष्पादित किया जाता है: किसी फ़ंक्शन में पहला कथन पहले निष्पादित किया जाता है, उसके बाद दूसरा, और इसी तरह।

प्रोग्रामिंग भाषाएँ विभिन्न नियंत्रण संरचनाएं प्रदान करती हैं जो अधिक जटिल निष्पादन पथों के लिए अनुमति देती हैं।

एक लूप स्टेटमेंट हमें कई बार स्टेटमेंट या स्टेटमेंट ऑफ स्टेट को निष्पादित करने की अनुमति देता है। VBA में लूप स्टेटमेंट का सामान्य रूप निम्नलिखित है।

VBA लूपिंग आवश्यकताओं को संभालने के लिए निम्न प्रकार के लूप प्रदान करता है। उनके विवरण की जाँच करने के लिए निम्न लिंक पर क्लिक करें।

अनु क्रमांक। लूप प्रकार और विवरण
1 पाश के लिए

कई बार बयानों का क्रम निष्पादित करता है और उस कोड को संक्षिप्त करता है जो लूप चर का प्रबंधन करता है।

2 ..चेक लूप के लिए

इसे तब निष्पादित किया जाता है जब समूह में कम से कम एक तत्व हो और समूह में प्रत्येक तत्व के लिए दोहराया जाए।

3 जबकि .. लूप भेजें

यह लूप बॉडी को निष्पादित करने से पहले स्थिति का परीक्षण करता है।

4 do.. लाइक लूप्स

Do..Wile स्टेटमेंट्स को तब तक निष्पादित किया जाएगा जब तक कि कंडीशन ट्रू है। (यानी,) लूप को तब तक दोहराया जाना चाहिए जब तक कि कंडीशन फाल्स न हो जाए।

5 do..until loops

Do..Until कथनों को तब तक निष्पादित किया जाएगा जब तक कि स्थिति गलत हो। (यानी,) लूप को तब तक दोहराया जाना चाहिए जब तक कि स्थिति सही न हो।

लूप नियंत्रण विवरण

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

VBA निम्नलिखित नियंत्रण कथनों का समर्थन करता है। उनके विवरण की जाँच करने के लिए निम्न लिंक पर क्लिक करें।

क्र.सं. नियंत्रण विवरण और विवरण
1 बयान के लिए बाहर निकलें

टर्मिनेट करता है For loop बयान और लूप के तुरंत बाद निष्पादन को बयान में स्थानांतरित करता है

2 एक्जिट डू स्टेटमेंट

टर्मिनेट करता है Do While बयान और लूप के तुरंत बाद निष्पादन को बयान में स्थानांतरित करता है

तार वर्णों का एक क्रम है, जिसमें वर्ण, संख्या, विशेष वर्ण या इन सभी को शामिल किया जा सकता है। एक चर को एक स्ट्रिंग कहा जाता है यदि यह दोहरे उद्धरण चिह्नों में संलग्न है ""।

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

variablename = "string"

उदाहरण

str1 = "string"   ' Only Alphabets
str2 = "132.45"   ' Only Numbers
str3 = "!@#$;*"  ' Only Special Characters
Str4 = "Asc23@#"  ' Has all the above

स्ट्रिंग फ़ंक्शंस

पूर्वनिर्धारित वीबीए स्ट्रिंग फ़ंक्शन हैं, जो डेवलपर्स को स्ट्रिंग्स के साथ बहुत प्रभावी ढंग से काम करने में मदद करते हैं। निम्नलिखित स्ट्रिंग विधियाँ हैं जो VBA में समर्थित हैं। कृपया विस्तार से जानने के लिए हर एक विधि पर क्लिक करें।

अनु क्रमांक। समारोह का नाम और विवरण
1 निर्देप्राप्तगुम

निर्दिष्ट प्रतिस्थापन की पहली घटना लौटाता है। खोज बाएं से दाएं होती है।

2 InstrRev

निर्दिष्ट प्रतिस्थापन की पहली घटना लौटाता है। खोज दाईं से बाईं ओर होती है।

3 Lcase

निर्दिष्ट स्ट्रिंग के निचले मामले को लौटाता है।

4 Ucase

निर्दिष्ट स्ट्रिंग के ऊपरी मामले को लौटाता है।

5 बाएं

स्ट्रिंग के बाईं ओर से वर्णों की एक विशिष्ट संख्या देता है।

6 सही

स्ट्रिंग के दाईं ओर से वर्णों की एक विशिष्ट संख्या देता है।

7 मध्य

निर्दिष्ट मापदंडों के आधार पर एक स्ट्रिंग से वर्णों की एक विशिष्ट संख्या देता है।

8 Ltrim

निर्दिष्ट स्ट्रिंग के बाईं ओर रिक्त स्थान को हटाने के बाद एक स्ट्रिंग लौटाता है।

9 Rtrim

निर्दिष्ट स्ट्रिंग के दाईं ओर रिक्त स्थान को हटाने के बाद एक स्ट्रिंग लौटाता है।

10 ट्रिम

अग्रणी और अनुगामी खाली स्थानों को हटाने के बाद एक स्ट्रिंग मान लौटाता है।

1 1 लेन

दिए गए स्ट्रिंग की लंबाई लौटाता है।

12 बदलने के

एक स्ट्रिंग को दूसरी स्ट्रिंग के साथ बदलने के बाद एक स्ट्रिंग लौटाता है।

13 अंतरिक्ष

रिक्त स्थान की निर्दिष्ट संख्या के साथ एक स्ट्रिंग को भरता है।

14 StrComp

दो निर्दिष्ट तारों की तुलना करने के बाद पूर्णांक मान लौटाता है।

15 तार

निर्दिष्ट समय के लिए एक निर्दिष्ट वर्ण के साथ एक स्ट्रिंग लौटाता है।

16 StrReverse

दिए गए स्ट्रिंग के वर्णों के क्रम को उलटने के बाद एक स्ट्रिंग लौटाता है।

VBScript दिनांक और समय फ़ंक्शंस डेवलपर्स को दिनांक और समय को एक प्रारूप से दूसरे स्वरूप में परिवर्तित करने या किसी विशिष्ट स्थिति के अनुरूप प्रारूप में दिनांक या समय मान को व्यक्त करने में मदद करते हैं।

दिनांक कार्य

अनु क्रमांक। समारोह विवरण
1 दिनांक

एक फ़ंक्शन, जो वर्तमान सिस्टम दिनांक लौटाता है।

2 CDate

एक फ़ंक्शन, जो किसी दिए गए इनपुट को दिनांक में परिवर्तित करता है।

3 DATEADD

एक फ़ंक्शन, जो एक तारीख लौटाता है जिसमें एक निर्दिष्ट समय अंतराल जोड़ा गया है।

4 DateDiff

एक फ़ंक्शन, जो दो समय अवधि के बीच का अंतर लौटाता है।

5 DatePart

एक फ़ंक्शन, जो दिए गए इनपुट दिनांक मान का एक निर्दिष्ट भाग लौटाता है।

6 DateSerial

एक फ़ंक्शन, जो दिए गए वर्ष, महीने और तारीख के लिए एक वैध तारीख देता है।

7 FormatDateTime

एक फ़ंक्शन, जो आपूर्ति किए गए मापदंडों के आधार पर तारीख को प्रारूपित करता है।

8 IsDate

एक फ़ंक्शन, जो एक बूलियन मान लौटाता है या नहीं आपूर्ति किया गया पैरामीटर एक तारीख है।

9 दिन

एक फ़ंक्शन, जो 1 और 31 के बीच पूर्णांक देता है जो निर्दिष्ट तिथि के दिन का प्रतिनिधित्व करता है।

10 महीना

एक फ़ंक्शन, जो 1 और 12 के बीच पूर्णांक देता है जो निर्दिष्ट तिथि के महीने का प्रतिनिधित्व करता है।

1 1 साल

एक फ़ंक्शन, जो एक पूर्णांक देता है जो निर्दिष्ट तिथि के वर्ष का प्रतिनिधित्व करता है।

12 MONTHNAME

एक फ़ंक्शन, जो निर्दिष्ट तिथि के लिए विशेष महीने का नाम देता है।

13 काम करने के दिन

एक फ़ंक्शन, जो पूर्णांक (1 से 7) देता है जो निर्दिष्ट दिन के लिए सप्ताह के दिन का प्रतिनिधित्व करता है।

14 WeekDayName

एक फ़ंक्शन, जो निर्दिष्ट दिन के लिए कार्यदिवस का नाम देता है।

समय कार्य

अनु क्रमांक। समारोह विवरण
1 अभी

एक फ़ंक्शन, जो वर्तमान सिस्टम दिनांक और समय लौटाता है।

2 इस घंटे

एक फ़ंक्शन, जो 0 और 23 के बीच पूर्णांक देता है जो दिए गए समय के घंटे के हिस्से का प्रतिनिधित्व करता है।

3 मिनट

एक फ़ंक्शन, जो 0 और 59 के बीच पूर्णांक देता है जो दिए गए समय के मिनट भाग का प्रतिनिधित्व करता है।

4 दूसरा

एक फ़ंक्शन, जो 0 और 59 के बीच पूर्णांक देता है जो दिए गए समय के सेकंड भाग का प्रतिनिधित्व करता है।

5 समय

एक फ़ंक्शन, जो वर्तमान सिस्टम समय लौटाता है।

6 घड़ी

एक फ़ंक्शन, जो 12:00 पूर्वाह्न से सेकंड और मिली सेकंड की संख्या लौटाता है।

7 TimeSerial

एक फ़ंक्शन, जो घंटे, मिनट और सेकंड के विशिष्ट इनपुट के लिए समय देता है।

8 समय की कीमत

एक फ़ंक्शन, जो इनपुट स्ट्रिंग को एक समय प्रारूप में परिवर्तित करता है।

हम अच्छी तरह से जानते हैं कि एक वैरिएबल एक स्टोर है जो एक वैल्यू को स्टोर करता है। कभी-कभी, डेवलपर्स एक बार में एक ही चर में एक से अधिक मूल्य रखने की स्थिति में होते हैं। जब किसी एकल चर में मानों की एक श्रृंखला संग्रहीत की जाती है, तो इसे ए के रूप में जाना जाता हैarray variable

ऐलान घोषणा

ऐरे को उसी तरह घोषित किया जाता है जिस तरह से एक वैरिएबल घोषित किया गया है सिवाय इसके कि ऐरे वेरिएबल की घोषणा कोष्ठक का उपयोग करती है। निम्नलिखित उदाहरण में, सरणी का आकार कोष्ठक में उल्लिखित है।

'Method 1 : Using Dim
Dim arr1()	'Without Size

'Method 2 : Mentioning the Size
Dim arr2(5)  'Declared with size of 5

'Method 3 : using 'Array' Parameter
Dim arr3
arr3 = Array("apple","Orange","Grapes")
  • हालाँकि, सरणी आकार 5 के रूप में इंगित किया गया है, यह 6 मान रख सकता है क्योंकि सरणी सूचकांक ZERO से शुरू होता है।

  • एरे इंडेक्स नकारात्मक नहीं हो सकता।

  • VBScript सरणी किसी भी प्रकार के चर को किसी सरणी में संग्रहीत कर सकती है। इसलिए, एक सरणी एकल सरणी चर में पूर्णांक, स्ट्रिंग या वर्णों को संग्रहीत कर सकती है।

मान को एक सरणी में सौंपना

असाइन किए जाने वाले मानों में से प्रत्येक के विरुद्ध एक सरणी इंडेक्स मान निर्दिष्ट करके मान को सरणी में असाइन किया गया है। यह एक तार हो सकता है।

उदाहरण

एक बटन जोड़ें और निम्नलिखित फ़ंक्शन जोड़ें।

Private Sub Constant_demo_Click()
   Dim arr(5)
   arr(0) = "1"           'Number as String
   arr(1) = "VBScript"    'String
   arr(2) = 100 		     'Number
   arr(3) = 2.45 		     'Decimal Number
   arr(4) = #10/07/2013#  'Date
   arr(5) = #12.45 PM#    'Time
  
   msgbox("Value stored in Array index 0 : " & arr(0))
   msgbox("Value stored in Array index 1 : " & arr(1))
   msgbox("Value stored in Array index 2 : " & arr(2))
   msgbox("Value stored in Array index 3 : " & arr(3))
   msgbox("Value stored in Array index 4 : " & arr(4))
   msgbox("Value stored in Array index 5 : " & arr(5))
End Sub

जब आप उपरोक्त फ़ंक्शन को निष्पादित करते हैं, तो यह निम्न आउटपुट का उत्पादन करता है।

Value stored in Array index 0 : 1
Value stored in Array index 1 : VBScript
Value stored in Array index 2 : 100
Value stored in Array index 3 : 2.45
Value stored in Array index 4 : 7/10/2013
Value stored in Array index 5 : 12:45:00 PM

मल्टी-डायमेंशनल एरे

एरे केवल एक आयाम तक सीमित नहीं हैं, हालांकि, उनके अधिकतम 60 आयाम हो सकते हैं। दो आयामी सरणियों सबसे अधिक इस्तेमाल किया वाले हैं।

उदाहरण

निम्नलिखित उदाहरण में, 3 पंक्तियों और 4 स्तंभों के साथ एक बहुआयामी सरणी घोषित किया गया है।

Private Sub Constant_demo_Click()
   Dim arr(2,3) as Variant	' Which has 3 rows and 4 columns
   arr(0,0) = "Apple" 
   arr(0,1) = "Orange"
   arr(0,2) = "Grapes"           
   arr(0,3) = "pineapple" 
   arr(1,0) = "cucumber"           
   arr(1,1) = "beans"           
   arr(1,2) = "carrot"           
   arr(1,3) = "tomato"           
   arr(2,0) = "potato"             
   arr(2,1) = "sandwitch"            
   arr(2,2) = "coffee"             
   arr(2,3) = "nuts"            
           
   msgbox("Value in Array index 0,1 : " &  arr(0,1))
   msgbox("Value in Array index 2,2 : " &  arr(2,2))
End Sub

जब आप उपरोक्त फ़ंक्शन को निष्पादित करते हैं, तो यह निम्न आउटपुट का उत्पादन करता है।

Value stored in Array index : 0 , 1 : Orange
Value stored in Array index : 2 , 2 : coffee

ReDim स्टेटमेंट

ReDim स्टेटमेंट का उपयोग डायनामिक-ऐरे वेरिएबल को घोषित करने और स्टोरेज स्पेस को आबंटित करने या पुनः प्राप्त करने के लिए किया जाता है।

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

ReDim [Preserve] varname(subscripts) [, varname(subscripts)]

पैरामीटर विवरण

  • Preserve - जब आप अंतिम आयाम के आकार को बदलते हैं, तो एक मौजूदा सरणी में डेटा को संरक्षित करने के लिए उपयोग किया जाने वाला वैकल्पिक पैरामीटर।

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

  • Subscripts - एक आवश्यक पैरामीटर, जो सरणी के आकार को इंगित करता है।

उदाहरण

निम्नलिखित उदाहरण में, एक सरणी को फिर से परिभाषित किया गया है और फिर सरणी के मौजूदा आकार को बदलने पर संरक्षित किए गए मान।

Note - मूल रूप से छोटे सरणी को आकार देने पर, समाप्त तत्वों में डेटा खो जाएगा।

Private Sub Constant_demo_Click()
   Dim a() as variant
   i = 0
   redim a(5)
   a(0) = "XYZ"
   a(1) = 41.25
   a(2) = 22
  
   REDIM PRESERVE a(7)
   For i = 3 to 7
   a(i) = i
   Next
  
   'to Fetch the output
   For i = 0 to ubound(a)
      Msgbox a(i)
   Next
End Sub

जब आप उपरोक्त फ़ंक्शन को निष्पादित करते हैं, तो यह निम्न आउटपुट का उत्पादन करता है।

XYZ
41.25
22
3
4
5
6
7

ऐरे तरीके

VBScript के भीतर विभिन्न इनबिल्ट फ़ंक्शन हैं जो डेवलपर्स को प्रभावी ढंग से सरणियों को संभालने में मदद करते हैं। सरणियों के साथ संयोजन में उपयोग किए जाने वाले सभी तरीकों को नीचे सूचीबद्ध किया गया है। कृपया इसके बारे में विस्तार से जानने के लिए विधि नाम पर क्लिक करें।

अनु क्रमांक। समारोह विवरण
1 LBound

एक फ़ंक्शन, जो पूर्णांक देता है जो दिए गए सरणियों की सबसे छोटी सबस्क्रिप्ट से मेल खाता है।

2 UBound

एक फ़ंक्शन, जो पूर्णांक देता है जो दिए गए सरणियों के सबसे बड़े सबस्क्रिप्ट से मेल खाता है।

3 विभाजित करें

एक फ़ंक्शन, जो एक सरणी देता है जिसमें निर्दिष्ट मान शामिल होते हैं। एक सीमांकक पर आधारित विभाजन।

4 शामिल हों

एक फंक्शन, जो एक स्ट्रिंग देता है जिसमें एक सरणी में निर्दिष्ट संख्या में सबस्ट्रिंग होते हैं। यह स्प्लिट विधि का एक सटीक विपरीत कार्य है।

5 फ़िल्टर

एक फ़ंक्शन, जो एक शून्य आधारित सरणी देता है जिसमें एक विशिष्ट फ़िल्टर मानदंड के आधार पर स्ट्रिंग सरणी का सबसेट होता है।

6 IsArray

एक फ़ंक्शन, जो एक बूलियन मान लौटाता है जो इंगित करता है कि इनपुट चर एक सरणी है या नहीं।

7 मिटाएं

एक फ़ंक्शन, जो सरणी चर के लिए आवंटित मेमोरी को पुनर्प्राप्त करता है।

functionपुन: प्रयोज्य कोड का एक समूह है जिसे आपके कार्यक्रम में कहीं भी बुलाया जा सकता है। यह एक ही कोड को बार-बार लिखने की आवश्यकता को समाप्त करता है। यह प्रोग्रामरों को एक बड़े कार्यक्रम को कई छोटे और प्रबंधनीय कार्यों में विभाजित करने में सक्षम बनाता है।

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

कार्य की परिभाषा

एक VBA फ़ंक्शन में वैकल्पिक रिटर्न स्टेटमेंट हो सकता है। यह आवश्यक है यदि आप किसी फ़ंक्शन से मान वापस करना चाहते हैं।

उदाहरण के लिए, आप एक फ़ंक्शन में दो नंबर पास कर सकते हैं और फिर आप फ़ंक्शन से अपने कॉलिंग प्रोग्राम में उनके गुणन को वापस करने की अपेक्षा कर सकते हैं।

Note - एक फ़ंक्शन, अल्पविराम द्वारा अलग किए गए कई मानों को फ़ंक्शन नाम को दिए गए सरणी के रूप में वापस कर सकता है।

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

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

एक बटन जोड़ें और निम्नलिखित फ़ंक्शन जोड़ें।

Function Functionname(parameter-list)
   statement 1
   statement 2
   statement 3
   .......
   statement n
End Function

उदाहरण

निम्नलिखित फ़ंक्शन जोड़ें जो क्षेत्र लौटाता है। ध्यान दें कि मान / मान फ़ंक्शन नाम के साथ ही वापस किए जा सकते हैं।

Function findArea(Length As Double, Optional Width As Variant)
   If IsMissing(Width) Then
      findArea = Length * Length
   Else
      findArea = Length * Width
   End If
End Function

एक समारोह बुला रहा है

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

नीचे दिखाए अनुसार क्षेत्र का आउटपुट उपयोगकर्ता को प्रदर्शित किया जाएगा।

Sub Procedures फ़ंक्शंस के समान हैं, हालांकि कुछ अंतर हैं।

  • उप-प्रक्रियाएँ मान वापस नहीं करती हैं जबकि फ़ंक्शन मान वापस कर सकते हैं या नहीं कर सकते हैं।

  • उप प्रक्रियाओं को बिना कॉल कीवर्ड के कहा जा सकता है।

  • उप प्रक्रियाओं को हमेशा उप और अंतिम उप कथनों के भीतर संलग्न किया जाता है।

उदाहरण

Sub Area(x As Double, y As Double)
   MsgBox x * y
End Sub

कॉलिंग प्रक्रिया

स्क्रिप्ट में कहीं एक प्रक्रिया को आमंत्रित करने के लिए, आप किसी फ़ंक्शन से कॉल कर सकते हैं। हम एक फ़ंक्शन के रूप में उसी तरह का उपयोग करने में सक्षम नहीं होंगे जैसे कि उप प्रक्रिया एक मूल्य वापस नहीं करेगी।

Function findArea(Length As Double, Width As Variant)
   area Length, Width    ' To Calculate Area 'area' sub proc is called
End Function

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

क्षेत्र की गणना और केवल संदेश बॉक्स में दिखाया गया है।

परिणाम सेल शून्य को प्रदर्शित करता है क्योंकि क्षेत्र मान फ़ंक्शन से वापस नहीं आता है। संक्षेप में, आप एक्सेल वर्कशीट से उप प्रक्रिया के लिए प्रत्यक्ष कॉल नहीं कर सकते।

जब आप सेल या सेल मानों की श्रेणी को मैन्युअल रूप से बदलते हैं तो VBA, एक ईवेंट-चालित प्रोग्रामिंग शुरू हो सकती है। परिवर्तन की घटना से चीजें आसान हो सकती हैं, लेकिन आप बहुत जल्दी स्वरूपण से भरे पृष्ठ को समाप्त कर सकते हैं। दो तरह के आयोजन होते हैं।

  • वर्कशीट इवेंट्स
  • वर्कबुक इवेंट्स

वर्कशीट इवेंट्स

वर्कशीट में बदलाव होने पर वर्कशीट इवेंट्स शुरू हो जाते हैं। इसे शीट टैब पर राइट-क्लिक करके और 'व्यू कोड' चुनकर, और बाद में कोड पेस्ट करके बनाया जाता है।

उपयोगकर्ता उन सभी कार्यपत्रकों में से प्रत्येक का चयन कर सकता है और सभी समर्थित वर्कशीट घटनाओं की सूची प्राप्त करने के लिए ड्रॉप डाउन से "वर्कशीट" चुन सकता है।

निम्नलिखित कार्यपत्रक ईवेंट हैं जिन्हें उपयोगकर्ता द्वारा जोड़ा जा सकता है।

Private Sub Worksheet_Activate() 
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)    
Private Sub Worksheet_BeforeRightClick(ByVal Target As Range, Cancel As Boolean) 
Private Sub Worksheet_Calculate() 
Private Sub Worksheet_Change(ByVal Target As Range) 
Private Sub Worksheet_Deactivate() 
Private Sub Worksheet_FollowHyperlink(ByVal Target As Hyperlink) 
Private Sub Worksheet_SelectionChange(ByVal Target As Range)

उदाहरण

बता दें, डबल क्लिक करने से पहले हमें एक मैसेज दिखाना होगा।

Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
   MsgBox "Before Double Click"
End Sub

उत्पादन

किसी भी सेल पर डबल-क्लिक करने पर, संदेश बॉक्स उपयोगकर्ता को प्रदर्शित होता है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

वर्कबुक इवेंट्स

जब पूरी कार्यपुस्तिका में कोई परिवर्तन होता है, तो कार्यपुस्तिका ईवेंट ट्रिगर हो जाते हैं। हम 'ThisWorkbook' का चयन करके और निम्न स्क्रीनशॉट में दिखाए अनुसार ड्रॉपडाउन से 'वर्कबुक' का चयन करके कार्यपुस्तिका घटनाओं के लिए कोड जोड़ सकते हैं। निम्न कार्यपुस्तिका_open उप प्रक्रिया उपयोगकर्ता को निम्न स्क्रीनशॉट में दिखाई देती है।

निम्नलिखित समर्थित वर्कबुक ईवेंट हैं जिन्हें उपयोगकर्ता द्वारा जोड़ा जा सकता है।

Private Sub Workbook_AddinUninstall() 
Private Sub Workbook_BeforeClose(Cancel As Boolean) 
Private Sub Workbook_BeforePrint(Cancel As Boolean) 
Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean) 
Private Sub Workbook_Deactivate() 
Private Sub Workbook_NewSheet(ByVal Sh As Object) 
Private Sub Workbook_Open() 
Private Sub Workbook_SheetActivate(ByVal Sh As Object) 
Private Sub Workbook_SheetBeforeDoubleClick(ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean) 
Private Sub Workbook_SheetBeforeRightClick(ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean) 
Private Sub Workbook_SheetCalculate(ByVal Sh As Object) 
Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range) 
Private Sub Workbook_SheetDeactivate(ByVal Sh As Object) 
Private Sub Workbook_SheetFollowHyperlink(ByVal Sh As Object, ByVal Target As Hyperlink) 
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range) 
Private Sub Workbook_WindowActivate(ByVal Wn As Window) 
Private Sub Workbook_WindowDeactivate(ByVal Wn As Window) 
Private Sub Workbook_WindowResize(ByVal Wn As Window)

उदाहरण

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

Private Sub Workbook_NewSheet(ByVal Sh As Object)
   MsgBox "New Sheet Created Successfully"
End Sub

उत्पादन

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

प्रोग्रामिंग में तीन प्रकार की त्रुटियां हैं: (ए) सिंटेक्स एरर्स, (बी) रनटाइम एरर्स और (सी) लॉजिकल एरर्स।

सिंटैक्स त्रुटियां

सिंटैक्स त्रुटियां, जिन्हें पार्सिंग त्रुटियां भी कहा जाता है, VBScript की व्याख्या के समय होती हैं। उदाहरण के लिए, निम्न पंक्ति एक सिंटैक्स त्रुटि का कारण बनती है क्योंकि यह एक बंद कोष्ठक को याद कर रही है।

Function ErrorHanlding_Demo()
   dim x,y
   x = "Tutorialspoint"
   y = Ucase(x
End Function

रनटाइम त्रुटियों

रनटाइम त्रुटि, जिसे अपवाद भी कहा जाता है, व्याख्या के बाद, निष्पादन के दौरान होती है।

उदाहरण के लिए, निम्न पंक्ति एक रनटाइम त्रुटि का कारण बनती है क्योंकि यहां सिंटैक्स सही है लेकिन रनटाइम में यह fnmultiply को कॉल करने का प्रयास कर रहा है, जो एक गैर-मौजूदा फ़ंक्शन है।

Function ErrorHanlding_Demo1()
   Dim x,y
   x = 10
   y = 20
   z = fnadd(x,y)
   a = fnmultiply(x,y)
End Function

Function fnadd(x,y)
   fnadd = x + y
End Function

तार्किक त्रुटियां

तार्किक त्रुटियाँ नीचे ट्रैक करने के लिए सबसे कठिन प्रकार की त्रुटियाँ हो सकती हैं। ये त्रुटियाँ सिंटैक्स या रनटाइम त्रुटि का परिणाम नहीं हैं। इसके बजाय, वे तब होते हैं जब आप तर्क में गलती करते हैं जो आपकी स्क्रिप्ट को ड्राइव करता है और आपको अपेक्षित परिणाम नहीं मिलता है।

आप उन त्रुटियों को नहीं पकड़ सकते, क्योंकि यह आपकी व्यावसायिक आवश्यकता पर निर्भर करता है कि आप अपने कार्यक्रम में किस प्रकार का तर्क रखना चाहते हैं।

उदाहरण के लिए, किसी संख्या को शून्य या एक लिपि से विभाजित करना जो लिखी जाती है जो अनंत लूप में प्रवेश करती है।

एरर ऑब्जेक्ट

मान लें कि यदि हमारे पास रनटाइम त्रुटि है, तो त्रुटि संदेश प्रदर्शित करके निष्पादन बंद हो जाता है। एक डेवलपर के रूप में, यदि हम त्रुटि को पकड़ना चाहते हैं, तोError वस्तु का उपयोग किया जाता है।

उदाहरण

निम्नलिखित उदाहरण में, Err.Number त्रुटि संख्या देता है और Err.Description त्रुटि विवरण देता है।

Err.Raise 6   ' Raise an overflow error.
MsgBox "Error # " & CStr(Err.Number) & " " & Err.Description
Err.Clear   ' Clear the error.

गलती संभालना

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

On Error { GoTo [ line | 0 | -1 ] | Resume Next }

अनु क्रमांक। कीवर्ड और विवरण
1

GoTo line

आवश्यक लाइन तर्क में निर्दिष्ट लाइन पर शुरू होने वाली त्रुटि-हैंडलिंग दिनचर्या को सक्षम करता है। निर्दिष्ट लाइन ऑन एरर स्टेटमेंट या कंपाइल-टाइम त्रुटि के समान प्रक्रिया में होनी चाहिए।

2

GoTo 0

सक्षम त्रुटि हैंडलर को वर्तमान प्रक्रिया में अक्षम करता है और इसे कुछ भी नहीं करने के लिए रीसेट करता है।

3

GoTo -1

वर्तमान प्रक्रिया में सक्षम अपवाद को अक्षम करता है और इसे कुछ भी नहीं करने के लिए रीसेट करता है।

4

Resume Next

निर्दिष्ट करता है कि जब कोई रन-टाइम त्रुटि होती है, तो नियंत्रण उस कथन के तुरंत बाद कथन पर जाता है जहां त्रुटि हुई थी, और निष्पादन उस बिंदु पर जारी है।

उदाहरण

Public Sub OnErrorDemo()
   On Error GoTo ErrorHandler   ' Enable error-handling routine.
   Dim x, y, z As Integer
   x = 50
   y = 0
   z = x / y   ' Divide by ZERO Error Raises
  
   ErrorHandler:    ' Error-handling routine.
   Select Case Err.Number   ' Evaluate error number.
      Case 10   ' Divide by zero error
         MsgBox ("You attempted to divide by zero!")
      Case Else
         MsgBox "UNKNOWN ERROR  - Error# " & Err.Number & " : " & Err.Description
   End Select
   Resume Next
End Sub

जब VBA का उपयोग करते हुए प्रोग्रामिंग करते हैं, तो कुछ महत्वपूर्ण वस्तुएं होती हैं जो एक उपयोगकर्ता के साथ काम करेगा।

  • आवेदन वस्तुओं
  • वर्कबुक ऑब्जेक्ट
  • वर्कशीट ऑब्जेक्ट्स
  • रेंज ऑब्जेक्ट्स

आवेदन वस्तुओं

अनुप्रयोग ऑब्जेक्ट में निम्न शामिल हैं -

  • एप्लिकेशन-वाइड सेटिंग्स और विकल्प।
  • शीर्ष-स्तरीय ऑब्जेक्ट्स, जैसे कि ActiveCell, ActiveSheet, और इसी तरह वापस आने वाले तरीके।

उदाहरण

'Example 1 :
Set xlapp = CreateObject("Excel.Sheet") 
xlapp.Application.Workbooks.Open "C:\test.xls"

'Example 2 :
Application.Windows("test.xls").Activate

'Example 3:
Application.ActiveCell.Font.Bold = True

वर्कबुक ऑब्जेक्ट

कार्यपुस्तिका ऑब्जेक्ट कार्यपुस्तिका संग्रह का एक सदस्य है और इसमें Microsoft Excel में वर्तमान में खुली सभी कार्यपुस्तिका ऑब्जेक्ट शामिल हैं।

उदाहरण

'Ex 1 : To close Workbooks
Workbooks.Close

'Ex 2 : To Add an Empty Work Book
Workbooks.Add

'Ex 3: To Open a Workbook
Workbooks.Open FileName:="Test.xls", ReadOnly:=True

'Ex : 4 - To Activate WorkBooks
Workbooks("Test.xls").Worksheets("Sheet1").Activate

वर्कशीट ऑब्जेक्ट्स

वर्कशीट ऑब्जेक्ट वर्क्सशीट संग्रह का एक सदस्य है और इसमें वर्कबुक में सभी वर्कशीट ऑब्जेक्ट शामिल हैं।

उदाहरण

'Ex 1 : To make it Invisible
Worksheets(1).Visible = False

'Ex 2 : To protect an WorkSheet
Worksheets("Sheet1").Protect password:=strPassword, scenarios:=True

रेंज ऑब्जेक्ट्स

रेंज ऑब्जेक्ट एक सेल, एक पंक्ति, एक कॉलम या कोशिकाओं के एक या अधिक निरंतर ब्लॉक वाले सेल का चयन करते हैं।

'Ex 1 : To Put a value in the cell A5
Worksheets("Sheet1").Range("A5").Value = "5235"

'Ex 2 : To put a value in range of Cells
Worksheets("Sheet1").Range("A1:A4").Value = 5

आप Excel फ़ाइल को भी पढ़ सकते हैं और सेल की सामग्री को VBA का उपयोग करके एक पाठ फ़ाइल में लिख सकते हैं। VBA दो तरीकों का उपयोग करके पाठ फ़ाइलों के साथ काम करने की अनुमति देता है -

  • फ़ाइल सिस्टम ऑब्जेक्ट
  • कमांड का उपयोग करना

फ़ाइल सिस्टम ऑब्जेक्ट (FSO)

जैसा कि नाम से पता चलता है, एफएसओ डेवलपर्स को ड्राइव, फोल्डर और फाइलों के साथ काम करने में मदद करता है। इस खंड में, हम चर्चा करेंगे कि एफएसओ का उपयोग कैसे करें।

अनु क्रमांक। ऑब्जेक्ट प्रकार और विवरण
1

Drive

ड्राइव एक वस्तु है। विधियाँ और गुण सम्‍मिलित करते हैं जो आपको सिस्टम से जुड़ी ड्राइव के बारे में जानकारी इकट्ठा करने की अनुमति देते हैं।

2

Drives

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

3

File

फ़ाइल एक वस्तु है। इसमें ऐसी विधियाँ और गुण हैं जो डेवलपर्स को फ़ाइल बनाने, हटाने या स्थानांतरित करने की अनुमति देते हैं।

4

Files

फ़ाइलें एक संग्रह है। यह एक फ़ोल्डर के भीतर निहित सभी फाइलों की एक सूची प्रदान करता है।

5

Folder

फ़ोल्डर एक ऑब्जेक्ट है। यह तरीके और गुण प्रदान करता है जो डेवलपर्स को फ़ोल्डर्स बनाने, हटाने या स्थानांतरित करने की अनुमति देता है।

6

Folders

फोल्डर्स एक संग्रह है। यह एक फ़ोल्डर के भीतर सभी फ़ोल्डरों की एक सूची प्रदान करता है।

7

TextStream

TextStream एक ऑब्जेक्ट है। यह डेवलपर्स को पाठ फ़ाइलों को पढ़ने और लिखने में सक्षम बनाता है।

चलाना

Driveएक ऑब्जेक्ट है, जो किसी विशेष डिस्क ड्राइव या नेटवर्क शेयर के गुणों तक पहुंच प्रदान करता है। निम्नलिखित गुणों द्वारा समर्थित हैंDrive वस्तु -

  • AvailableSpace
  • DriveLetter
  • DriveType
  • FileSystem
  • FreeSpace
  • IsReady
  • Path
  • RootFolder
  • SerialNumber
  • ShareName
  • TotalSize
  • VolumeName

उदाहरण

Step 1- FSO का उपयोग करके स्क्रिप्टिंग के लिए आगे बढ़ने से पहले, हमें Microsoft स्क्रिप्टिंग रनटाइम को सक्षम करना चाहिए। ऐसा करने के लिए, निम्न स्क्रीनशॉट में दिखाए गए अनुसार टूल → सन्दर्भ में नेविगेट करें।

Step 2 - "Microsoft स्क्रिप्टिंग रनटाइम" जोड़ें और ठीक पर क्लिक करें।

Step 3 - वह डेटा जोड़ें, जिसे आप टेक्स्ट फाइल में लिखना चाहते हैं और कमांड बटन जोड़ें।

Step 4 - अब यह स्क्रिप्ट का समय है।

Private Sub fn_write_to_text_Click()
   Dim FilePath As String
   Dim CellData As String
   Dim LastCol As Long
   Dim LastRow As Long
  
   Dim fso As FileSystemObject
   Set fso = New FileSystemObject
   Dim stream As TextStream
  
   LastCol = ActiveSheet.UsedRange.Columns.Count
   LastRow = ActiveSheet.UsedRange.Rows.Count
    
   ' Create a TextStream.
   Set stream = fso.OpenTextFile("D:\Try\Support.log", ForWriting, True)
  
   CellData = ""
  
   For i = 1 To LastRow
      For j = 1 To LastCol
         CellData = Trim(ActiveCell(i, j).Value)
         stream.WriteLine "The Value at location (" & i & "," & j & ")" & CellData
      Next j
   Next i
  
   stream.Close
   MsgBox ("Job Done")
End Sub

उत्पादन

स्क्रिप्ट निष्पादित करते समय, सुनिश्चित करें कि आप वर्कशीट के पहले सेल में कर्सर रखते हैं। Support.log फ़ाइल को निम्न D में "D: \ Try" के अनुसार दिखाया गया है।

फ़ाइल के विषय निम्नलिखित स्क्रीनशॉट में दिखाए गए हैं।

कमांड लिखो

एफएसओ के विपरीत, हमें किसी भी संदर्भ को जोड़ने की आवश्यकता नहीं है, हालांकि, हम ड्राइव, फ़ाइलों और फ़ोल्डरों के साथ काम नहीं कर पाएंगे। हम केवल पाठ फ़ाइल में स्ट्रीम जोड़ पाएंगे।

उदाहरण

Private Sub fn_write_to_text_Click()
   Dim FilePath As String
   Dim CellData As String
   Dim LastCol As Long
   Dim LastRow As Long
  
   LastCol = ActiveSheet.UsedRange.Columns.Count
   LastRow = ActiveSheet.UsedRange.Rows.Count
    
   FilePath = "D:\Try\write.txt"
   Open FilePath For Output As #2
  
   CellData = ""
   For i = 1 To LastRow
      For j = 1 To LastCol
         CellData = "The Value at location (" & i & "," & j & ")" & Trim(ActiveCell(i, j).Value)
         Write #2, CellData
      Next j
   Next i
  
   Close #2
   MsgBox ("Job Done")
End Sub

उत्पादन

स्क्रिप्ट निष्पादित करने पर, "write.txt" फ़ाइल "D: \ Try" स्थान पर बनाई गई है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

फ़ाइल की सामग्री को निम्न स्क्रीनशॉट में दिखाया गया है।

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

Step 1 - वह डेटा दर्ज करें जिसके खिलाफ ग्राफ उत्पन्न करना है।

Step 2 - 3 बटन बनाएं - एक बार ग्राफ उत्पन्न करने के लिए, दूसरा पाई चार्ट बनाने के लिए और दूसरा कॉलम चार्ट बनाने के लिए।

Step 3 - इन प्रकार के चार्ट में से प्रत्येक को उत्पन्न करने के लिए मैक्रो विकसित करें।

' Procedure to Generate Pie Chart
Private Sub fn_generate_pie_graph_Click()
   Dim cht As ChartObject
   For Each cht In Worksheets(1).ChartObjects
      cht.Chart.Type = xlPie
   Next cht
End Sub

' Procedure to Generate Bar Graph
Private Sub fn_Generate_Bar_Graph_Click()
   Dim cht As ChartObject
   For Each cht In Worksheets(1).ChartObjects
      cht.Chart.Type = xlBar
   Next cht
End Sub

' Procedure to Generate Column Graph
Private Sub fn_generate_column_graph_Click()
   Dim cht As ChartObject
   For Each cht In Worksheets(1).ChartObjects
      cht.Chart.Type = xlColumn
   Next cht
End Sub

Step 4- संबंधित बटन पर क्लिक करने पर, चार्ट बनाया जाता है। निम्नलिखित आउटपुट में, जनरेट चार्ट बटन पर क्लिक करें।

User Formएक कस्टम-निर्मित संवाद बॉक्स है जो उपयोगकर्ता के लिए उपयोगकर्ता डेटा प्रविष्टि को अधिक नियंत्रणीय और उपयोग करने में आसान बनाता है। इस अध्याय में, आप एक सरल रूप तैयार करना और डेटा को एक्सेल में जोड़ना सीखेंगे।

Step 1- Alt + F11 दबाकर VBA विंडो में नेविगेट करें और "इन्सर्ट" मेनू में नेविगेट करें और "यूजर फॉर्म" चुनें। चयन करने पर, उपयोगकर्ता फॉर्म को निम्न स्क्रीनशॉट में दिखाया गया है।

Step 2 - दिए गए नियंत्रणों का उपयोग करके प्रपत्रों को डिज़ाइन करें।

Step 3- प्रत्येक नियंत्रण को जोड़ने के बाद, नियंत्रणों को नाम देना होगा। कैप्शन जो प्रपत्र पर दिखाई देता है उससे मेल खाता है और नाम उस तार्किक नाम से मेल खाता है जो उस तत्व के लिए VBA कोड लिखते समय दिखाई देगा।

Step 4 - निम्नलिखित नियंत्रणों में से प्रत्येक के नाम निम्नलिखित हैं।

नियंत्रण तार्किक नाम शीर्षक
से frmempform कर्मचारी फॉर्म
कर्मचारी आईडी लेबल बॉक्स empid कर्मचारी कामतत्व
Firstname लेबल बॉक्स पहला नाम पहला नाम
lastname लेबल बॉक्स उपनाम उपनाम
dob लेबल बॉक्स जन्म तिथि जन्म की तारीख
mailid लेबल बॉक्स mailid ईमेल आईडी
Passportholder लेबल बॉक्स पासपोर्ट धारक पासपोर्ट धारक
ईएम आईडी टेक्स्ट बॉक्स txtempid लागू नहीं
पहला नाम टेक्स्ट बॉक्स txtfirstname लागू नहीं
अंतिम नाम टेक्स्ट बॉक्स txtlastname लागू नहीं
ईमेल आईडी टेक्स्ट बॉक्स txtemailid लागू नहीं
डेट कॉम्बो बॉक्स cmbdate लागू नहीं
महीना कॉम्बो बॉक्स cmbmonth लागू नहीं
साल कॉम्बो बॉक्स cmbyear लागू नहीं
हाँ रेडियो बटन radioyes हाँ
कोई रेडियो बटन नहीं radiono नहीं
जमा करने वाला बटन btnSubmit प्रस्तुत
बटन रद्द करें btncancel रद्द करना

Step 5 - फ़ॉर्म पर राइट-क्लिक करके और 'कोड देखें' का चयन करके फ़ॉर्म लोड घटना के लिए कोड जोड़ें।

Step 6 - ऑब्जेक्ट ड्रॉप-डाउन से 'यूजरफॉर्म' का चयन करें और निम्न स्क्रीनशॉट में दिखाए गए अनुसार 'इनिशियलाइज़' विधि का चयन करें।

Step 7 - फ़ॉर्म को लोड करने पर, सुनिश्चित करें कि टेक्स्ट बॉक्स साफ़ हो गए हैं, ड्रॉप-डाउन बॉक्स भरे गए हैं और रेडियो बटन रीसेट हो गए हैं।

Private Sub UserForm_Initialize()
   'Empty Emp ID Text box and Set the Cursor 
   txtempid.Value = ""
   txtempid.SetFocus
   
   'Empty all other text box fields
   txtfirstname.Value = ""
   txtlastname.Value = ""
   txtemailid.Value = ""
   
   'Clear All Date of Birth Related Fields
   cmbdate.Clear
   cmbmonth.Clear
   cmbyear.Clear
   
   'Fill Date Drop Down box - Takes 1 to 31
   With cmbdate
      .AddItem "1"
      .AddItem "2"
      .AddItem "3"
      .AddItem "4"
      .AddItem "5"
      .AddItem "6"
      .AddItem "7"
      .AddItem "8"
      .AddItem "9"
      .AddItem "10"
      .AddItem "11"
      .AddItem "12"
      .AddItem "13"
      .AddItem "14"
      .AddItem "15"
      .AddItem "16"
      .AddItem "17"
      .AddItem "18"
      .AddItem "19"
      .AddItem "20"
      .AddItem "21"
      .AddItem "22"
      .AddItem "23"
      .AddItem "24"
      .AddItem "25"
      .AddItem "26"
      .AddItem "27"
      .AddItem "28"
      .AddItem "29"
      .AddItem "30"
      .AddItem "31"
   End With
   
   'Fill Month Drop Down box - Takes Jan to Dec
   With cmbmonth
      .AddItem "JAN"
      .AddItem "FEB"
      .AddItem "MAR"
      .AddItem "APR"
      .AddItem "MAY"
      .AddItem "JUN"
      .AddItem "JUL"
      .AddItem "AUG"
      .AddItem "SEP"
      .AddItem "OCT"
      .AddItem "NOV"
      .AddItem "DEC"
   End With
   
   'Fill Year Drop Down box - Takes 1980 to 2014
   With cmbyear
      .AddItem "1980"
      .AddItem "1981"
      .AddItem "1982"
      .AddItem "1983"
      .AddItem "1984"
      .AddItem "1985"
      .AddItem "1986"
      .AddItem "1987"
      .AddItem "1988"
      .AddItem "1989"
      .AddItem "1990"
      .AddItem "1991"
      .AddItem "1992"
      .AddItem "1993"
      .AddItem "1994"
      .AddItem "1995"
      .AddItem "1996"
      .AddItem "1997"
      .AddItem "1998"
      .AddItem "1999"
      .AddItem "2000"
      .AddItem "2001"
      .AddItem "2002"
      .AddItem "2003"
      .AddItem "2004"
      .AddItem "2005"
      .AddItem "2006"
      .AddItem "2007"
      .AddItem "2008"
      .AddItem "2009"
      .AddItem "2010"
      .AddItem "2011"
      .AddItem "2012"
      .AddItem "2013"
      .AddItem "2014"
   End With
   
   'Reset Radio Button. Set it to False when form loads.
   radioyes.Value = False
   radiono.Value = False

End Sub

Step 8- अब कोड को सबमिट बटन पर जोड़ें। सबमिट बटन पर क्लिक करने पर, उपयोगकर्ता को वर्कशीट में मान जोड़ने में सक्षम होना चाहिए।

Private Sub btnsubmit_Click()
   Dim emptyRow As Long
  
   'Make Sheet1 active
   Sheet1.Activate
  
   'Determine emptyRow
   emptyRow = WorksheetFunction.CountA(Range("A:A")) + 1
  
   'Transfer information
   Cells(emptyRow, 1).Value = txtempid.Value
   Cells(emptyRow, 2).Value = txtfirstname.Value
   Cells(emptyRow, 3).Value = txtlastname.Value
   Cells(emptyRow, 4).Value = cmbdate.Value & "/" & cmbmonth.Value & "/" & cmbyear.Value
   Cells(emptyRow, 5).Value = txtemailid.Value
  
   If radioyes.Value = True Then
      Cells(emptyRow, 6).Value = "Yes"
   Else
      Cells(emptyRow, 6).Value = "No"
   End If
End Sub

Step 9 - उपयोगकर्ता द्वारा रद्द करें बटन पर क्लिक करने पर फ़ॉर्म को बंद करने के लिए एक विधि जोड़ें।

Private Sub btncancel_Click()
   Unload Me
End Sub

Step 10- "रन" बटन पर क्लिक करके फॉर्म को निष्पादित करें। फ़ॉर्म में मान दर्ज करें और 'सबमिट' बटन पर क्लिक करें। निम्न स्क्रीनशॉट में दिखाए अनुसार स्वचालित रूप से मान कार्यपत्रक में प्रवाहित होंगे।