এক্সেল সূত্র দিয়ে VBA কম্পাইলার ত্রুটি বোঝা এবং ঠিক করা
Excel এর সাথে কাজ করার সময়, আপনি দেখতে পারেন যে নির্দিষ্ট সূত্রগুলি, যেমন SERIESSUM ফাংশন, ওয়ার্কশীটের মধ্যে পুরোপুরি কাজ করে কিন্তু VBA কোডে প্রয়োগ করা হলে সমস্যা সৃষ্টি করে। এই বৈপরীত্য হতাশাজনক হতে পারে, বিশেষ করে যখন আপনি উভয় পরিবেশে সামঞ্জস্যপূর্ণ ফলাফল আশা করেন।
এই নিবন্ধে, আমরা VBA-তে SERIESSUM ফাংশন ব্যবহার করার সময় সম্মুখীন একটি সাধারণ কম্পাইলার ত্রুটি অন্বেষণ করব। আমরা কোড বিশ্লেষণ করব, ত্রুটির মূল কারণ শনাক্ত করব এবং আপনার VBA কোড আপনার এক্সেল সূত্রের মতো একই ফলাফল তৈরি করবে তা নিশ্চিত করার জন্য একটি সমাধান প্রদান করব।
আদেশ | বর্ণনা |
---|---|
Application.WorksheetFunction.SeriesSum | Excel এ SERIESSUM ফাংশনের অনুরূপ একটি পাওয়ার সিরিজের যোগফল গণনা করে৷ |
Application.WorksheetFunction.Index | সারি এবং কলাম সংখ্যা সূচী দ্বারা নির্বাচিত একটি টেবিল বা অ্যারেতে একটি উপাদানের মান প্রদান করে। |
Set | একটি ভেরিয়েবল বা সম্পত্তি একটি বস্তুর রেফারেন্স বরাদ্দ করতে ব্যবহৃত. |
Variant | একটি VBA ডেটা টাইপ যা এই উদাহরণে অ্যারেগুলির জন্য ব্যবহৃত যে কোনও ধরণের ডেটা ধারণ করতে পারে। |
ActiveWorkbook | বর্তমানে সক্রিয় ওয়ার্কবুক উল্লেখ করে। |
Range("range_name").Value | Excel এ নির্দিষ্ট নামকৃত পরিসরের মান পায় বা সেট করে। |
এক্সেল সূত্রের জন্য VBA কোড বোঝা
প্রথম স্ক্রিপ্ট উদাহরণে, আমরা ব্যবহার করার সময় যে ত্রুটির সম্মুখীন হয়েছিল তা সমাধান করি VBA এর মধ্যে ফাংশন। স্ক্রিপ্টটি প্রয়োজনীয় ভেরিয়েবল ঘোষণা করে শুরু হয়, সহ কাজের বইয়ের জন্য, ওয়ার্কশীটের জন্য, output পরিসীমা এবং অ্যারের জন্য এবং . পরিবর্তনশীল এর ফলাফল সংরক্ষণ করতে ব্যবহৃত হয় SeriesSum ফাংশন সক্রিয় ওয়ার্কবুক এবং নির্দিষ্ট ওয়ার্কশীট সেট করার পরে, স্ক্রিপ্ট ওয়ার্কশীটে নির্দিষ্ট রেঞ্জ উল্লেখ করে অ্যারেগুলিতে মান নির্ধারণ করে। দ্য তারপর ফাংশন বলা হয়, প্যারামিটারগুলি ব্যবহার করে পুনরুদ্ধার করা হয় ফাংশন, মূল এক্সেল সূত্র মিররিং।
দ্বিতীয় স্ক্রিপ্ট একটি অনুরূপ পদ্ধতি অনুসরণ করে কিন্তু সরাসরি নামকৃত রেঞ্জ উল্লেখ করে এবং ব্যবহার এবং Value. এটি নিশ্চিত করে যে অ্যারেগুলিকে পাস করার আগে সঠিকভাবে পপুলেট করা হয়েছে ফাংশন এর ব্যবহার এবং সঠিক ওয়ার্কবুক এবং ওয়ার্কশীট ব্যবহার করা হয়েছে তা নিশ্চিত করে। চূড়ান্ত ফলাফল "স্থির স্রোত" শীটের AB1 কক্ষে স্থাপন করা হয়, এটি প্রদর্শন করে যে এক্সেলে সম্পাদিত একই ক্রিয়াকলাপগুলি VBA-তে প্রতিলিপি করা যেতে পারে, যার ফলে ধারাবাহিক ফলাফল পাওয়া যায়। এই স্ক্রিপ্টগুলি দেখায় কিভাবে এক্সেলের অন্তর্নির্মিত ফাংশন এবং VBA কোডের মধ্যে ব্যবধান পূরণ করা যায়, সমস্ত পরামিতি সঠিকভাবে সংজ্ঞায়িত এবং পাস হয়েছে তা নিশ্চিত করে 'আর্গুমেন্ট নয় ঐচ্ছিক' ত্রুটির সমাধান করে।
এক্সেল সূত্রে VBA আর্গুমেন্ট ঐচ্ছিক ত্রুটি নয় ঠিক করা
আর্গুমেন্ট ইস্যু সংশোধন করতে VBA কোড
Sub Corrected_Stuff()
Dim wb As Workbook
Dim ws As Worksheet
Dim output As Range
Dim volt_array As Variant
Dim coef_array As Variant
Dim var As Double
Set wb = ActiveWorkbook
Set ws = wb.Sheets("fixed currents")
volt_array = ws.Range("A1:A10").Value
coef_array = ws.Range("B1:B10").Value
var = 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 = var
End Sub
এক্সেল ভিবিএ-তে কম্পাইলার ত্রুটিগুলি সমাধান করা
সিরিজসম ফাংশনের জন্য সামঞ্জস্য করা VBA স্ক্রিপ্ট
Sub Fixed_Stuff()
Dim wb As Workbook
Dim ws As Worksheet
Dim output As Range
Dim volt_array As Variant
Dim coef_array As Variant
Dim var As Double
Set wb = ActiveWorkbook
Set ws = wb.Sheets("fixed currents")
volt_array = Range("volt_array").Value
coef_array = Range("coef_array").Value
var = 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 = var
End Sub
VBA এবং Excel ফাংশন ইন্টিগ্রেশন অন্বেষণ
Excel এবং VBA এর সাথে কাজ করার সময়, Excel এর অন্তর্নির্মিত ফাংশন এবং VBA কোডের মধ্যে ব্যবধান কীভাবে পূরণ করা যায় তা বোঝা গুরুত্বপূর্ণ। একটি গুরুত্বপূর্ণ দিক হল অ্যারেগুলি পরিচালনা করা এবং ডেটা প্রকারগুলি সঠিকভাবে পরিচালিত হয় তা নিশ্চিত করা। এক্সেলে যেমন ফাংশন এবং সহজবোধ্য, কিন্তু VBA এই ফাংশনগুলি পরিচালনা করার জন্য একটি ভিন্ন পদ্ধতির প্রয়োজন। এতে VBA এর অন্তর্নির্মিত ব্যবহার জড়িত আপনার কোডের মধ্যে এই ফাংশনগুলি কল করার জন্য সম্পত্তি। আরেকটি অপরিহার্য দিক হল ভেরিয়েবলের সঠিক ঘোষণা। এক্সেল সূত্রের বিপরীতে, ত্রুটি এড়াতে VBA ডেটা প্রকারের সুস্পষ্ট ঘোষণার প্রয়োজন। আমাদের উদাহরণে, ব্যবহার করে Variant অ্যারে এবং জন্য ফলাফল নিশ্চিত করে যে সমস্ত স্ক্রিপ্ট জুড়ে ডেটা সঠিকভাবে পরিচালনা করা হয়েছে।
উপরন্তু, কিভাবে সেট করতে হয় এবং রেফারেন্স রেঞ্জ করতে হয় তা বোঝা গুরুত্বপূর্ণ। ব্যবহার রেঞ্জ এবং ওয়ার্কবুক রেফারেন্স বরাদ্দ করা আপনাকে আপনার ওয়ার্কবুকের নির্দিষ্ট অংশগুলিকে প্রোগ্রাম্যাটিকভাবে পরিচালনা করতে দেয়। Excel এ নামকৃত রেঞ্জের সাথে ডিল করার সময় এটি বিশেষভাবে কার্যকর। সঠিক রেফারেন্স নিশ্চিত করে যে সঠিক তথ্য পুনরুদ্ধার করা হয়েছে এবং প্রক্রিয়া করা হয়েছে। উপরন্তু, VBA এর সাথে কাজ করার সময় ত্রুটি হ্যান্ডলিং এবং ডিবাগিং গুরুত্বপূর্ণ দক্ষতা। ত্রুটি হ্যান্ডলিং মেকানিজম প্রয়োগ করা সমস্যাগুলি প্রাথমিকভাবে চিহ্নিত করে এবং তথ্যপূর্ণ ত্রুটি বার্তা প্রদান করে অনেক সময় এবং হতাশা বাঁচাতে পারে। এই অনুশীলনগুলি শুধুমাত্র আপনার VBA স্ক্রিপ্টগুলির নির্ভরযোগ্যতা বাড়ায় না বরং ভবিষ্যতের প্রকল্পগুলির জন্য তাদের আরও রক্ষণাবেক্ষণযোগ্য এবং মাপযোগ্য করে তোলে।
- আমি কিভাবে VBA তে এক্সেল ফাংশন ব্যবহার করব?
- ব্যবহার করুন এক্সেল ফাংশনের নাম অনুসরণ করে।
- কি ভিবিএতে ডেটা টাইপ?
- একটি ডেটা টাইপ যা যেকোনো ধরনের ডেটা ধরে রাখতে পারে, অ্যারেগুলির জন্য দরকারী।
- আমি কিভাবে VBA এ একটি নামকৃত পরিসর উল্লেখ করতে পারি?
- ব্যবহার করুন নামকৃত রেঞ্জ উল্লেখ করতে।
- কি করে VBA তে করবেন?
- এটি একটি ভেরিয়েবল বা সম্পত্তির একটি অবজেক্ট রেফারেন্স বরাদ্দ করে।
- কেন আমি একটি "আর্গুমেন্ট ঐচ্ছিক নয়" ত্রুটি পাচ্ছি?
- এই ত্রুটিটি ঘটে যখন একটি প্রয়োজনীয় আর্গুমেন্ট একটি ফাংশন কলে অনুপস্থিত থাকে।
- আমি কিভাবে VBA কোড ডিবাগ করতে পারি?
- ব্রেকপয়েন্ট ব্যবহার করুন, অবিলম্বে উইন্ডো, এবং ডিবাগ করার জন্য কোডের মাধ্যমে ধাপ করুন।
- কি ?
- VBA-তে পাওয়ার সিরিজের যোগফল গণনা করার একটি পদ্ধতি।
- আমি কিভাবে VBA তে অ্যারে পরিচালনা করব?
- হিসাবে অ্যারে ঘোষণা এবং রেঞ্জ ব্যবহার করে মান নির্ধারণ করুন।
- আমি কিভাবে নিশ্চিত করতে পারি যে আমার VBA কোড এক্সেল সূত্রের সাথে মেলে?
- সঠিকভাবে পরামিতি পাস করে এবং ডেটা প্রকারগুলি পরিচালনা করে, আপনি ধারাবাহিক ফলাফল নিশ্চিত করতে পারেন।
আপনার এক্সেল সূত্রগুলি VBA-এর মধ্যে নির্বিঘ্নে কাজ করে তা নিশ্চিত করার জন্য বিশদ বিবরণে সতর্ক মনোযোগ প্রয়োজন, বিশেষ করে ডেটার ধরন এবং ফাংশন প্যারামিটারগুলির সাথে কাজ করার সময়। কিভাবে সঠিকভাবে Application.WorksheetFunction, রেফারেন্স নামের রেঞ্জ এবং হ্যান্ডেল অ্যারে ব্যবহার করতে হয় তা বোঝার মাধ্যমে, আপনি "আর্গুমেন্ট ঐচ্ছিক নয়" এর মতো সাধারণ ত্রুটিগুলি এড়াতে পারেন৷ প্রদত্ত সমাধানগুলি প্রদর্শন করে কিভাবে কার্যকরভাবে এক্সেল সূত্রগুলিকে VBA কোডে অনুবাদ করতে হয়, আপনার প্রকল্পগুলিতে নির্ভরযোগ্য এবং সামঞ্জস্যপূর্ণ ফলাফল নিশ্চিত করে৷