எக்செல் ஃபார்முலாக்களுடன் VBA கம்பைலர் பிழைகளைப் புரிந்துகொண்டு சரிசெய்தல்
எக்செல் உடன் பணிபுரியும் போது, SRIESSUM செயல்பாடு போன்ற சில சூத்திரங்கள் பணித்தாளில் சரியாக வேலை செய்வதை நீங்கள் காணலாம், ஆனால் VBA குறியீட்டில் செயல்படுத்தப்படும் போது சிக்கல்களை ஏற்படுத்தும். இந்த முரண்பாடு ஏமாற்றமளிக்கும், குறிப்பாக இரு சூழல்களிலும் நிலையான முடிவுகளை நீங்கள் எதிர்பார்க்கும் போது.
இந்த கட்டுரையில், VBA இல் SERIESSUM செயல்பாட்டைப் பயன்படுத்தும் போது ஏற்படும் பொதுவான கம்பைலர் பிழையை ஆராய்வோம். நாங்கள் குறியீட்டை பகுப்பாய்வு செய்வோம், பிழையின் மூல காரணத்தைக் கண்டறிவோம், மேலும் உங்கள் VBA குறியீடு உங்கள் Excel சூத்திரங்களைப் போன்ற முடிவுகளைத் தருகிறது என்பதை உறுதிப்படுத்த ஒரு தீர்வை வழங்குவோம்.
| கட்டளை | விளக்கம் |
|---|---|
| Application.WorksheetFunction.SeriesSum | Excel இல் உள்ள SERIESSUM செயல்பாட்டைப் போலவே பவர் தொடரின் கூட்டுத்தொகையைக் கணக்கிடுகிறது. |
| Application.WorksheetFunction.Index | வரிசை மற்றும் நெடுவரிசை எண் குறியீடுகளால் தேர்ந்தெடுக்கப்பட்ட அட்டவணை அல்லது அணிவரிசையில் உள்ள உறுப்பின் மதிப்பை வழங்கும். |
| Set | ஒரு மாறி அல்லது சொத்துக்கு ஒரு பொருள் குறிப்பை ஒதுக்க பயன்படுகிறது. |
| Variant | இந்த எடுத்துக்காட்டில் அணிகளுக்குப் பயன்படுத்தப்படும் எந்த வகையான தரவையும் கொண்டிருக்கக்கூடிய VBA தரவு வகை. |
| ActiveWorkbook | தற்போது செயலில் உள்ள பணிப்புத்தகத்தைக் குறிக்கிறது. |
| Range("range_name").Value | Excel இல் குறிப்பிடப்பட்ட பெயரிடப்பட்ட வரம்பின் மதிப்புகளைப் பெறுகிறது அல்லது அமைக்கிறது. |
எக்செல் ஃபார்முலாக்களுக்கான VBA குறியீட்டைப் புரிந்துகொள்வது
முதல் ஸ்கிரிப்ட் எடுத்துக்காட்டில், பயன்படுத்தும்போது ஏற்படும் பிழையை நாங்கள் நிவர்த்தி செய்கிறோம் VBA க்குள் செயல்பாடு. உள்ளிட்ட தேவையான மாறிகளை அறிவிப்பதன் மூலம் ஸ்கிரிப்ட் தொடங்குகிறது பணிப்புத்தகத்திற்கு, பணித்தாள்க்கு, output வரம்பு மற்றும் அணிவரிசைகளுக்கு மற்றும் . மாறி இதன் முடிவைச் சேமிக்கப் பயன்படுகிறது SeriesSum செயல்பாடு. செயலில் உள்ள பணிப்புத்தகம் மற்றும் குறிப்பிட்ட பணித்தாள் அமைத்த பிறகு, ஸ்கிரிப்ட் பணித்தாளில் குறிப்பிட்ட வரம்புகளைக் குறிப்பிடுவதன் மூலம் அணிகளுக்கு மதிப்புகளை ஒதுக்குகிறது. தி செயல்பாடு பின்னர் அழைக்கப்படுகிறது, அளவுருக்கள் பயன்படுத்தி மீட்டெடுக்கப்படும் செயல்பாடு, அசல் எக்செல் சூத்திரத்தை பிரதிபலிக்கிறது.
இரண்டாவது ஸ்கிரிப்ட் இதேபோன்ற அணுகுமுறையைப் பின்பற்றுகிறது, ஆனால் பெயரிடப்பட்ட வரம்புகளை நேரடியாகக் குறிப்பிடுகிறது மற்றும் பயன்படுத்தி மற்றும் Value. வரிசைகளை அனுப்புவதற்கு முன், அவை சரியாக நிரப்பப்பட்டிருப்பதை இது உறுதி செய்கிறது செயல்பாடு. பயன்பாடு மற்றும் சரியான பணிப்புத்தகம் மற்றும் பணித்தாள் பயன்படுத்தப்படுவதை உறுதி செய்கிறது. இறுதி முடிவு "நிலையான மின்னோட்டங்கள்" தாளின் செல் AB1 இல் வைக்கப்பட்டுள்ளது, Excel இல் செய்யப்படும் அதே செயல்பாடுகளை VBA இல் மீண்டும் செய்ய முடியும் என்பதை நிரூபிக்கிறது, இதன் மூலம் நிலையான முடிவுகளை உருவாக்குகிறது. இந்த ஸ்கிரிப்ட்கள் எக்செல் இன் உள்ளமைக்கப்பட்ட செயல்பாடுகள் மற்றும் VBA குறியீடு ஆகியவற்றுக்கு இடையே உள்ள இடைவெளியைக் குறைப்பது எப்படி என்பதைக் காட்டுகிறது, எல்லா அளவுருக்களும் சரியாக வரையறுக்கப்பட்டு அனுப்பப்படுவதை உறுதி செய்வதன் மூலம் 'ஆர்குமெண்ட் விருப்பமில்லை' பிழையைத் தீர்க்கிறது.
எக்செல் ஃபார்முலாவில் VBA வாதத்தை சரிசெய்வது விருப்பப் பிழை அல்ல
வாத சிக்கலை சரிசெய்ய VBA குறியீடு
Sub Corrected_Stuff()Dim wb As WorkbookDim ws As WorksheetDim output As RangeDim volt_array As VariantDim coef_array As VariantDim var As DoubleSet wb = ActiveWorkbookSet ws = wb.Sheets("fixed currents")volt_array = ws.Range("A1:A10").Valuecoef_array = ws.Range("B1:B10").Valuevar = Application.WorksheetFunction.SeriesSum(Application.WorksheetFunction.Index(volt_array, 2),0,1,Application.WorksheetFunction.Index(coef_array, 1, 1))Set output = ws.Range("AB1")output.Value = varEnd Sub
எக்செல் விபிஏவில் கம்பைலர் பிழைகளைத் தீர்ப்பது
SeriesSum செயல்பாட்டிற்கான VBA ஸ்கிரிப்ட் சரிசெய்யப்பட்டது
Sub Fixed_Stuff()Dim wb As WorkbookDim ws As WorksheetDim output As RangeDim volt_array As VariantDim coef_array As VariantDim var As DoubleSet wb = ActiveWorkbookSet ws = wb.Sheets("fixed currents")volt_array = Range("volt_array").Valuecoef_array = Range("coef_array").Valuevar = Application.WorksheetFunction.SeriesSum(Application.WorksheetFunction.Index(volt_array, 2),0,1,Application.WorksheetFunction.Index(coef_array, 1, 1))Set output = ws.Range("AB1")output.Value = varEnd Sub
விபிஏ மற்றும் எக்செல் செயல்பாடு ஒருங்கிணைப்பை ஆய்வு செய்தல்
எக்செல் மற்றும் விபிஏ உடன் பணிபுரியும் போது, எக்செல் இன் உள்ளமைக்கப்பட்ட செயல்பாடுகள் மற்றும் விபிஏ குறியீடு ஆகியவற்றுக்கு இடையே உள்ள இடைவெளியை எவ்வாறு இணைப்பது என்பதைப் புரிந்துகொள்வது முக்கியம். ஒரு முக்கியமான அம்சம் வரிசைகளைக் கையாள்வது மற்றும் தரவு வகைகள் சரியாக நிர்வகிக்கப்படுவதை உறுதி செய்வது. எக்செல் இல், போன்ற செயல்பாடுகள் மற்றும் நேரடியானவை, ஆனால் இந்த செயல்பாடுகளை கையாள VBA க்கு வேறுபட்ட அணுகுமுறை தேவைப்படுகிறது. இது VBA இன் உள்ளமைவைப் பயன்படுத்துவதை உள்ளடக்கியது உங்கள் குறியீட்டிற்குள் இந்த செயல்பாடுகளை அழைக்க சொத்து. மற்றொரு முக்கியமான அம்சம் மாறிகளின் சரியான அறிவிப்பு ஆகும். எக்செல் சூத்திரங்களைப் போலன்றி, பிழைகளைத் தவிர்க்க VBA க்கு தரவு வகைகளின் வெளிப்படையான அறிவிப்பு தேவைப்படுகிறது. எங்கள் எடுத்துக்காட்டில், பயன்படுத்தி Variant வரிசைகள் மற்றும் ஸ்கிரிப்ட் முழுவதும் தரவு சரியாக கையாளப்படுவதை இதன் விளைவாக உறுதி செய்கிறது.
கூடுதலாக, வரம்புகளை எவ்வாறு அமைப்பது மற்றும் குறிப்பிடுவது என்பதைப் புரிந்துகொள்வது முக்கியமானது. பயன்படுத்தி வரம்புகள் மற்றும் பணிப்புத்தக குறிப்புகளை ஒதுக்குவது உங்கள் பணிப்புத்தகத்தின் குறிப்பிட்ட பகுதிகளை நிரல் ரீதியாக கையாள உங்களை அனுமதிக்கிறது. Excel இல் பெயரிடப்பட்ட வரம்புகளைக் கையாளும் போது இது மிகவும் பயனுள்ளதாக இருக்கும். சரியான குறிப்பு சரியான தரவு மீட்டெடுக்கப்பட்டு செயலாக்கப்படுவதை உறுதி செய்கிறது. மேலும், VBA உடன் பணிபுரியும் போது பிழை கையாளுதல் மற்றும் பிழைத்திருத்தம் ஆகியவை முக்கியமான திறன்களாகும். பிழையைக் கையாளும் வழிமுறைகளைச் செயல்படுத்துவது, சிக்கல்களை முன்கூட்டியே கண்டறிந்து, தகவல் தரும் பிழைச் செய்திகளை வழங்குவதன் மூலம் நிறைய நேரத்தையும் ஏமாற்றத்தையும் மிச்சப்படுத்தலாம். இந்த நடைமுறைகள் உங்கள் VBA ஸ்கிரிப்ட்களின் நம்பகத்தன்மையை மேம்படுத்துவது மட்டுமல்லாமல், எதிர்கால திட்டங்களுக்கு அவற்றை மேலும் பராமரிக்கக்கூடியதாகவும் அளவிடக்கூடியதாகவும் ஆக்குகிறது.
- VBA இல் எக்செல் செயல்பாடுகளை எவ்வாறு பயன்படுத்துவது?
- பயன்படுத்தவும் அதைத் தொடர்ந்து எக்செல் செயல்பாடு பெயர்.
- என்ன VBA இல் தரவு வகை?
- வரிசைகளுக்குப் பயனுள்ள, எந்த வகையான தரவையும் வைத்திருக்கக்கூடிய தரவு வகை.
- VBA இல் பெயரிடப்பட்ட வரம்பை நான் எவ்வாறு குறிப்பிடுவது?
- பயன்படுத்தவும் பெயரிடப்பட்ட வரம்புகளைக் குறிப்பிடுவதற்கு.
- என்ன செய்கிறது VBA இல் செய்யவா?
- இது ஒரு மாறி அல்லது சொத்துக்கு ஒரு பொருள் குறிப்பை ஒதுக்குகிறது.
- நான் ஏன் "விருப்பம் அல்ல" பிழையைப் பெறுகிறேன்?
- செயல்பாட்டு அழைப்பில் தேவையான வாதம் இல்லாதபோது இந்தப் பிழை ஏற்படுகிறது.
- VBA குறியீட்டை எவ்வாறு பிழைத்திருத்துவது?
- ப்ரேக் பாயிண்ட்ஸ், உடனடி சாளரம் மற்றும் பிழைத்திருத்தத்திற்கு குறியீடு மூலம் படி ஆகியவற்றைப் பயன்படுத்தவும்.
- என்ன ?
- VBA இல் ஒரு சக்தித் தொடரின் கூட்டுத்தொகையைக் கணக்கிடுவதற்கான ஒரு முறை.
- VBA இல் வரிசைகளை எவ்வாறு கையாள்வது?
- வரிசைகளை இவ்வாறு அறிவிக்கவும் வரம்புகளைப் பயன்படுத்தி மதிப்புகளை ஒதுக்கவும்.
- எனது VBA குறியீடு எக்செல் ஃபார்முலாக்களுடன் பொருந்துகிறது என்பதை நான் எப்படி உறுதிப்படுத்துவது?
- அளவுருக்களை சரியாகக் கடந்து தரவு வகைகளைக் கையாள்வதன் மூலம், நீங்கள் நிலையான முடிவுகளை உறுதி செய்யலாம்.
உங்கள் எக்செல் ஃபார்முலாக்கள் VBA க்குள் தடையின்றி செயல்படுவதை உறுதிசெய்ய, குறிப்பாக தரவு வகைகள் மற்றும் செயல்பாட்டு அளவுருக்களைக் கையாளும் போது, விவரங்களுக்கு கவனமாக கவனம் தேவை. Application.WorksheetFunction, குறிப்பு பெயரிடப்பட்ட வரம்புகள் மற்றும் வரிசைகளை எவ்வாறு சரியாகப் பயன்படுத்துவது என்பதைப் புரிந்துகொள்வதன் மூலம், "வாதம் விருப்பமில்லை" போன்ற பொதுவான பிழைகளைத் தவிர்க்கலாம். எக்செல் ஃபார்முலாக்களை VBA குறியீடாக எவ்வாறு திறம்பட மொழிபெயர்ப்பது, உங்கள் திட்டங்களில் நம்பகமான மற்றும் நிலையான விளைவுகளை உறுதிசெய்வது என்பதை வழங்கியுள்ள தீர்வுகள் விளக்குகின்றன.