Skill

Functions এবং Procedures (ফাংশন এবং প্রসিডিউর)

ভিবিএ (VBA) - Computer Programming

497

VBA তে ফাংশন এবং প্রসিডিউর (Functions and Procedures in VBA)

VBA (Visual Basic for Applications) প্রোগ্রামিং ভাষায় ফাংশন (Functions) এবং প্রসিডিউর (Procedures) অত্যন্ত গুরুত্বপূর্ণ উপাদান। এই দুটি প্রোগ্রামিং ধারণা কোডের পুনঃব্যবহারযোগ্যতা, কার্যকারিতা এবং লজিকাল গঠন উন্নত করতে সহায়ক। একে অপর থেকে কিছু পার্থক্য রয়েছে, এবং তাদের নিজস্ব উদ্দেশ্য ও ব্যবহার রয়েছে।


প্রসিডিউর (Procedure)

প্রসিডিউর হলো একটি কোড ব্লক যা কিছু নির্দিষ্ট কাজ বা কার্য সম্পাদন করে। এটি সাধারণত একটি নির্দিষ্ট কাজ বা সিরিজ কাজ করতে ব্যবহৃত হয় এবং সাধারণভাবে কোনো মান রিটার্ন করে না।

Types of Procedures:

  1. Sub Procedures (Subroutine):
    • Sub Procedures বা Subroutines হলো সাধারণ প্রসিডিউর, যেগুলি কিছু নির্দিষ্ট কাজ সম্পাদন করে কিন্তু কোনো মান রিটার্ন করে না।
    • একে Sub কীওয়ার্ড দিয়ে ডিফাইন করা হয় এবং সাধারণত এটি একাধিক স্টেটমেন্ট নিয়ে গঠিত থাকে যা কোডের নির্দিষ্ট অংশের কাজ সম্পাদন করে।
    • Sub প্রোগ্রামের মধ্যে কোড ব্লক হিসেবে কাজ করে।

সিনট্যাক্স:

Sub ProcedureName()
    ' Code to perform a specific task
End Sub

উদাহরণ:

Sub ShowMessage()
    MsgBox "Hello, World!"
End Sub

এখানে, ShowMessage একটি Sub procedure, যা "Hello, World!" মেসেজটি প্রদর্শন করবে।

  1. With...End With Block:
    • একটি With ব্লক ব্যবহার করে আপনি একই অবজেক্টের উপর একাধিক কার্যক্রম করতে পারেন, যা কোডকে আরো পরিষ্কার এবং কার্যকর করে।

উদাহরণ:

Sub FormatCell()
    With Range("A1")
        .Value = "Hello"
        .Font.Bold = True
        .Font.Size = 14
    End With
End Sub

এখানে, Range("A1") সেলের উপর একাধিক ফর্ম্যাটিং কাজ করা হয়েছে।


ফাংশন (Function)

ফাংশন হলো একটি কোড ব্লক যা কোনো ইনপুট নিয়ে কিছু কাজ করে এবং একটি নির্দিষ্ট মান রিটার্ন করে। এটি সাধারণত গাণিতিক হিসাব বা কোনো প্রসেসিং কাজের জন্য ব্যবহৃত হয়, এবং পরবর্তীতে সেই মান ব্যবহারের জন্য ফেরত দেয়।

Function Procedures:

  • Functions ব্যবহৃত হয় একটি মান রিটার্ন করতে। এর মাধ্যমে আপনি একাধিক গাণিতিক, লজিক্যাল বা ডেটা প্রসেসিং কাজ সম্পাদন করতে পারেন এবং সেই ফলাফল অন্য কোথাও ব্যবহার করতে পারেন।
  • Function প্রোগ্রামটি সম্পন্ন করার পর একটি মান রিটার্ন করে, যেটি পরবর্তীতে অন্য কোন কোডে ব্যবহৃত হতে পারে।

সিনট্যাক্স:

Function FunctionName() As DataType
    ' Code to perform some task
    FunctionName = result
End Function

উদাহরণ:

Function AddNumbers(a As Integer, b As Integer) As Integer
    AddNumbers = a + b
End Function

এখানে, AddNumbers একটি ফাংশন যা দুটি পূর্ণসংখ্যার যোগফল প্রদান করবে। আপনি এই ফাংশনটি অন্য কোডে ব্যবহার করতে পারেন:

Sub TestFunction()
    Dim result As Integer
    result = AddNumbers(5, 7)
    MsgBox result ' আউটপুট হবে 12
End Sub

ফাংশন এবং প্রসিডিউরের মধ্যে পার্থক্য

বিষয়প্রসিডিউর (Sub)ফাংশন (Function)
রিটার্ন মানকোনো মান রিটার্ন করে না।একটি মান রিটার্ন করে।
ব্যবহারনির্দিষ্ট কাজ বা সিরিজ কাজ সম্পাদন করতে ব্যবহৃত।নির্দিষ্ট মান বা হিসাব রিটার্ন করতে ব্যবহৃত।
ডিফাইন করার জন্য কীওয়ার্ডSub ব্যবহার করা হয়।Function ব্যবহার করা হয়।
ফলাফল ব্যবহৃতসাধারণত অন্য কোনো প্রোগ্রামে ব্যবহৃত হয় না।রিটার্ন করা মান অন্যান্য প্রোগ্রামে ব্যবহৃত হতে পারে।
এখন পর্যন্ত ব্যবহারের উদ্দেশ্যপ্রোগ্রাম বা কোডের বিভিন্ন অংশে নির্দিষ্ট কাজ চালানো।গাণিতিক হিসাব, ডেটা প্রসেসিং এবং ফলাফল ফেরত প্রদান।

সারসংক্ষেপ

  • প্রসিডিউর (Sub): কোনো নির্দিষ্ট কাজ বা কার্য সম্পাদন করে এবং কোনো মান রিটার্ন করে না। এটি সাধারণত কাজের সিরিজ পরিচালনা করে।
  • ফাংশন (Function): কোনো নির্দিষ্ট কাজের মাধ্যমে একটি মান রিটার্ন করে এবং সেই মান পরে অন্য কোডে ব্যবহার করা যেতে পারে।

ফাংশন এবং প্রসিডিউর ব্যবহার করলে কোডের পুনঃব্যবহারযোগ্যতা এবং কার্যকারিতা অনেক বৃদ্ধি পায়, এবং কোড লেখাও সহজ ও সংগঠিত হয়।

Content added By

Functions এবং Sub Procedures এর মৌলিক ধারণা

প্রোগ্রামিং ভাষায় Functions এবং Sub Procedures হল দুটি প্রধান ধরনের প্রোগ্রামিং ব্লক যা পুনরাবৃত্তিমূলক কোড লেখা এবং কোডের পুনর্ব্যবহারযোগ্যতা বৃদ্ধি করতে ব্যবহৃত হয়। VBA (Visual Basic for Applications)-এ এই দুটি কনসেপ্ট খুবই গুরুত্বপূর্ণ এবং প্রায় সব প্রোগ্রামেই ব্যবহৃত হয়।

১. Sub Procedures (Subroutines)

Sub Procedure বা Sub হল এমন একটি ব্লক কোড যা কোনো নির্দিষ্ট কাজ সম্পন্ন করে এবং কোনো মান রিটার্ন (return) করে না। Sub Procedure মূলত কিছু নির্দেশনা বা কোডের ব্লক হিসেবে কাজ করে। Sub ব্যবহার করে আপনি একাধিক কোড লাইনের কাজকে একত্রিত করতে পারেন এবং সেই কাজটি পুনরায় প্রয়োজনমতো কল (call) করতে পারেন।

সিনট্যাক্স:

Sub SubProcedureName()
    ' কোড যা চালানো হবে
End Sub

উদাহরণ (VBA):

Sub ShowMessage()
    MsgBox "Hello, this is a Sub Procedure"
End Sub

এখানে, ShowMessage একটি Sub Procedure যা যখন কল করা হয়, তখন একটি মেসেজ বক্সে "Hello, this is a Sub Procedure" প্রদর্শিত হয়।

Sub Procedure এর বৈশিষ্ট্য:

  • এটি কোনো মান রিটার্ন করে না।
  • একাধিক কাজ করতে পারে।
  • কোনো আর্গুমেন্ট (arguments) পাস করা যেতে পারে (যদি প্রয়োজন হয়)।
  • কোডের পুনরায় ব্যবহারযোগ্যতার জন্য উপযোগী।

উদাহরণ: Sub Procedure with Arguments

Sub AddNumbers(a As Integer, b As Integer)
    MsgBox "The sum of the numbers is: " & (a + b)
End Sub

এখানে, AddNumbers Sub Procedure দুটি ইনপুট নেয় এবং তাদের যোগফল মেসেজ বক্সে দেখায়।


২. Functions

Function হল এমন একটি প্রোগ্রামিং ব্লক যা নির্দিষ্ট কাজ সম্পন্ন করার পর একটি মান (value) রিটার্ন করে। সাধারণত, Functions গণনা বা কোন নির্দিষ্ট লজিকের জন্য ব্যবহৃত হয় এবং ফলস্বরূপ একটি ফলাফল রিটার্ন করে। Function রিটার্ন করা মান ব্যবহারকারীর কাছে পৌঁছানোর জন্য প্রস্তুত থাকে।

সিনট্যাক্স:

Function FunctionName() As DataType
    ' কোড যা কাজ করবে
End Function

উদাহরণ (VBA):

Function AddNumbers(a As Integer, b As Integer) As Integer
    AddNumbers = a + b
End Function

এখানে, AddNumbers একটি Function যা দুটি সংখ্যা নেবে এবং তাদের যোগফল রিটার্ন করবে।

Function এর বৈশিষ্ট্য:

  • এটি একটি মান রিটার্ন করে (যেমন Integer, String, Boolean ইত্যাদি)।
  • একাধিক আর্গুমেন্ট গ্রহণ করতে পারে।
  • সাধারণত গণনা বা লজিক্যাল কাজের জন্য ব্যবহৃত হয়।
  • একটি Function কল করার সময় রিটার্ন মানটি ব্যবহার করা যায়।

উদাহরণ: Function with Return Value

Function Multiply(a As Integer, b As Integer) As Integer
    Multiply = a * b
End Function

এখানে, Multiply একটি Function যা দুটি সংখ্যাকে গুণ করে এবং তার ফলাফল রিটার্ন করে। আপনি এটি এমনভাবে কল করতে পারেন:

Dim result As Integer
result = Multiply(4, 5)
MsgBox "The result is: " & result

এতে "The result is: 20" মেসেজ বক্সে প্রদর্শিত হবে।


৩. Sub Procedures এবং Functions এর মধ্যে পার্থক্য

বৈশিষ্ট্যSub ProcedureFunction
রিটার্ন ভ্যালুকোন মান রিটার্ন করে না।একটি মান রিটার্ন করে।
ব্যবহারপ্রধানত কাজ সম্পাদন করা এবং আউটপুট প্রদর্শন করা।গণনা বা লজিক্যাল কাজের জন্য, এবং রিটার্ন ভ্যালু ব্যবহার করা।
কোড কলSub Procedure কে Call অথবা সরাসরি কল করা যায়।Function কে সরাসরি কোডে ব্যবহার করা হয়, এবং রিটার্ন ভ্যালু ব্যবহার করা যায়।
ডেটা টাইপডেটা টাইপ নির্দিষ্ট করা হয় না (অথবা Sub কোডে এটি প্রয়োজন হয় না)।Function এর জন্য অবশ্যই রিটার্ন ভ্যালুর ডেটা টাইপ নির্দিষ্ট করতে হয়।

৪. প্রয়োজনীয় ব্যবহার

  • Sub Procedure ব্যবহার করা হয় যখন আপনার শুধু কাজ সম্পাদন করতে হবে, কিন্তু কোনো মান রিটার্ন করতে হবে না (যেমন— মেসেজ বক্স প্রদর্শন, ডেটা প্রিন্ট করা, ফাইল অপেন করা ইত্যাদি)।
  • Function ব্যবহার করা হয় যখন আপনি কোনো নির্দিষ্ট গণনা বা লজিক সম্পন্ন করার পর ফলাফল রিটার্ন করতে চান, যাতে সেই মান অন্য কোথাও ব্যবহার করা যায় (যেমন— গাণিতিক হিসাব, স্ট্রিং প্রক্রিয়াকরণ ইত্যাদি)।

উপসংহার

  • Sub Procedures এবং Functions উভয়ই কোডকে পুনর্ব্যবহারযোগ্য ও সংগঠিত রাখতে সহায়ক, তবে তাদের উদ্দেশ্য ভিন্ন। Sub Procedures সাধারণত কোডের কার্য সম্পাদন করে, তবে কোন মান রিটার্ন করে না। Functions কাজ করার পর একটি নির্দিষ্ট মান রিটার্ন করে যা অন্যান্য কোডে ব্যবহৃত হতে পারে।

এগুলি ব্যবহারের মাধ্যমে আপনি কোডকে আরও মডুলার, পরিষ্কার এবং পুনর্ব্যবহারযোগ্য করতে পারেন।

Content added By

VBA-তে Function তৈরি এবং ব্যবহার

VBA (Visual Basic for Applications)-এ Function তৈরি করা এবং ব্যবহার করা একটি শক্তিশালী পদ্ধতি যা আপনাকে পুনরায় ব্যবহারের জন্য কোড লিখতে সহায়তা করে। Function হল একটি কোড ব্লক যা নির্দিষ্ট কাজ সম্পাদন করে এবং একটি মান রিটার্ন করে। যখন একই কাজ বারবার করার প্রয়োজন হয়, তখন ফাংশন ব্যবহার করা খুবই কার্যকরী।

Function কী?

ফাংশন হল একটি ব্লক কোড যা একটি নির্দিষ্ট কাজ সম্পাদন করে এবং সাধারণত একটি মান রিটার্ন করে। ফাংশনটি পুনরায় ব্যবহারযোগ্য, অর্থাৎ একবার তৈরি করার পর আপনি যে কোনো সময় এই ফাংশনটি ব্যবহার করতে পারেন।

Function তৈরি করার গঠন (Syntax)

Function FunctionName(Parameters) As ReturnType
    ' Function Body (যেখানে কাজ করা হবে)
    FunctionName = result ' রিটার্ন মান সেট করুন
End Function
  • FunctionName: এটি আপনার ফাংশনের নাম যা আপনি দিতে চান।
  • Parameters: এটি ঐচ্ছিক (যদি প্রয়োজন হয়) এবং ফাংশনে পাস করা আর্গুমেন্ট বা ইনপুট মান।
  • ReturnType: এটি সেই ডেটা টাইপ যা ফাংশনটি রিটার্ন করবে (যেমন: Integer, String, Boolean ইত্যাদি)।
  • Function Body: এখানে আপনি আপনার ফাংশনের কাজ বা লজিক লিখবেন।

Function তৈরি এবং ব্যবহার: উদাহরণ

১. সহজ একটি Function তৈরি

ধরা যাক, আপনি একটি ফাংশন তৈরি করতে চান যা দুটি সংখ্যা যোগ করবে এবং তাদের ফলাফল রিটার্ন করবে।

Function AddNumbers(num1 As Integer, num2 As Integer) As Integer
    AddNumbers = num1 + num2 ' যোগফল রিটার্ন
End Function

এখানে, AddNumbers নামের একটি ফাংশন তৈরি করা হয়েছে যা দুটি পূর্ণসংখ্যা গ্রহণ করে এবং তাদের যোগফল রিটার্ন করবে।

ফাংশনটি ব্যবহার করা

এখন, আমরা এই ফাংশনটি কোনো সাবরুটিন বা কোডে ব্যবহার করতে পারি।

Sub TestAdd()
    Dim result As Integer
    result = AddNumbers(10, 20) ' ফাংশন কল করা
    MsgBox "The sum is " & result
End Sub

এখানে, TestAdd সাবরুটিনটি AddNumbers ফাংশন কল করে দুটি সংখ্যা যোগ করে এবং ফলাফল একটি মেসেজবক্সে দেখায়।

২. String Return Function

একটি ফাংশন তৈরি করা যেটি একটি স্ট্রিং রিটার্ন করবে:

Function GreetUser(name As String) As String
    GreetUser = "Hello, " & name & "!" ' গ্রিটিং স্ট্রিং রিটার্ন
End Function

এটি একটি স্ট্রিং প্যারামিটার নেবে এবং সেই অনুযায়ী একটি গ্রিটিং মেসেজ রিটার্ন করবে।

ফাংশনটি ব্যবহার করা

Sub TestGreeting()
    Dim greeting As String
    greeting = GreetUser("John") ' ফাংশন কল করা
    MsgBox greeting ' "Hello, John!" মেসেজ দেখাবে
End Sub

এখানে, TestGreeting সাবরুটিনটি GreetUser ফাংশন কল করে এবং "Hello, John!" মেসেজটি মেসেজবক্সে দেখায়।

৩. Boolean Return Function

ধরা যাক, আমরা একটি ফাংশন তৈরি করতে চাই যা একটি বয়স গ্রহণ করবে এবং এটি চেক করবে যে, ব্যক্তি পূর্ণবয়স্ক (১৮ বছর বা তার বেশি) কি না।

Function IsAdult(age As Integer) As Boolean
    If age >= 18 Then
        IsAdult = True ' পূর্ণবয়স্ক হলে True রিটার্ন
    Else
        IsAdult = False ' নয়তো False রিটার্ন
    End If
End Function

ফাংশনটি ব্যবহার করা

Sub TestAdultCheck()
    Dim result As Boolean
    result = IsAdult(20) ' ফাংশন কল করা
    If result Then
        MsgBox "The person is an adult."
    Else
        MsgBox "The person is not an adult."
    End If
End Sub

এখানে, TestAdultCheck সাবরুটিনটি IsAdult ফাংশন কল করে এবং নির্ধারণ করে যে ব্যক্তি পূর্ণবয়স্ক কি না, তারপর ফলাফল অনুযায়ী মেসেজ দেখায়।


Function এর উপকারিতা:

  1. পুনরাবৃত্তি এড়ানো: যখন একই কোড বারবার ব্যবহার করতে হয়, তখন ফাংশন ব্যবহার করলে কোডের পুনরাবৃত্তি কমে এবং আপনার প্রোগ্রাম আরও সোজা হয়ে ওঠে।
  2. পাঠযোগ্যতা: ফাংশন কোডকে ছোট ছোট অংশে ভাগ করে দেয়, যা কোডের পাঠযোগ্যতা এবং মেইনটেনেবিলিটি উন্নত করে।
  3. কোড রিইউজ: একবার ফাংশন তৈরি করা হলে, আপনি এই ফাংশনটি বারবার বিভিন্ন জায়গায় ব্যবহার করতে পারবেন, এতে সময় এবং প্রচেষ্টা সাশ্রয় হয়।

ফাংশন থেকে মান রিটার্ন না করা (Missing Return Value)

যদি ফাংশনটি কোনো মান রিটার্ন না করে, তবে এর ডেটা টাইপ হবে Sub (যা কেবল কিছু কাজ সম্পাদন করে)। তবে ফাংশনটির ক্ষেত্রে এক বা একাধিক মান রিটার্ন করার সম্ভাবনা থাকে।

Sub PrintGreeting(name As String)
    MsgBox "Hello, " & name
End Sub

এখানে, PrintGreeting একটি Sub (ফাংশন নয়) যা কোনো মান রিটার্ন করে না, কেবল একটি বার্তা প্রদর্শন করে।


উপসংহার

ফাংশন হল VBA প্রোগ্রামিংয়ের একটি অপরিহার্য অংশ যা নির্দিষ্ট কাজ সম্পাদন করে এবং একটি মান রিটার্ন করে। একাধিক বার একই কাজ করা এবং কোড পুনরায় ব্যবহারযোগ্য করতে ফাংশন তৈরি করা গুরুত্বপূর্ণ। এটি কোডকে আরও মডুলার, পরিষ্কার এবং পরিচালনাযোগ্য করে তোলে।

Content added By

VBA তে Parameters এবং Return Values

VBA (Visual Basic for Applications) তে Parameters এবং Return Values একটি ফাংশন বা সাবরুটিনের মধ্যে ইনপুট এবং আউটপুট ডেটা হ্যান্ডেল করার জন্য ব্যবহৃত হয়। এগুলো কোডের কার্যকারিতা বৃদ্ধি করতে এবং পুনর্ব্যবহারযোগ্যতা নিশ্চিত করতে গুরুত্বপূর্ণ ভূমিকা পালন করে। নিচে Parameters এবং Return Values সম্পর্কে বিস্তারিত আলোচনা এবং উদাহরণ দেওয়া হলো।


1. Parameters (প্যারামিটারস)

Parameters হলো ফাংশন বা সাবরুটিনের জন্য ইনপুট ভেরিয়েবল যা ফাংশন বা সাবরুটিন কল করার সময় মূল্যায়ন করা হয়। প্যারামিটার ব্যবহার করে আপনি ফাংশন বা সাবরুটিনের মধ্যে ডেটা পাস করতে পারেন। প্যারামিটার সাধারণত ফাংশনের বা সাবরুটিনের সিগনেচারে (signature) উল্লেখ করা হয়।

Parameter Types:

  1. ByVal (By Value):
    • এটি প্যারামিটারটি ফাংশনে পাস করার সময় তার মানের কপি তৈরি করে।
    • ফাংশনের ভিতরে প্যারামিটারটি পরিবর্তিত হলেও, বাহিরে এর মান অপরিবর্তিত থাকে।
  2. ByRef (By Reference):
    • এটি প্যারামিটারটি ফাংশনে পাস করার সময় তার রেফারেন্স (অথবা আসল ঠিকানা) পাস করে।
    • ফাংশনের ভিতরে প্যারামিটারটি পরিবর্তিত হলে বাহিরেও তার মান পরিবর্তিত হয়।

Parameters এর উদাহরণ:

Sub ExampleByVal()
    Dim num As Integer
    num = 5
    MsgBox "Before: " & num
    IncreaseByVal num
    MsgBox "After ByVal: " & num
End Sub

Sub IncreaseByVal(ByVal value As Integer)
    value = value + 1
End Sub

এখানে, IncreaseByVal ফাংশনটি ByVal প্যারামিটার ব্যবহার করে। প্যারামিটার value এর কপি পাস করা হয়েছে, তাই মূল ভেরিয়েবল num এর মান অপরিবর্তিত থাকে।


Sub ExampleByRef()
    Dim num As Integer
    num = 5
    MsgBox "Before: " & num
    IncreaseByRef num
    MsgBox "After ByRef: " & num
End Sub

Sub IncreaseByRef(ByRef value As Integer)
    value = value + 1
End Sub

এখানে, IncreaseByRef ফাংশনটি ByRef প্যারামিটার ব্যবহার করে, যার ফলে num এর মান পরিবর্তিত হয়।


2. Return Values (রিটার্ন ভ্যালু)

Return Value হলো ফাংশন থেকে আউটপুট যা ফাংশন সম্পন্ন হওয়ার পর ফেরত দেয়। একটি ফাংশন সাধারণত কিছু মান হিসেব করে সেই মানটি ফেরত পাঠায়, যা পরে অন্যান্য কোডে ব্যবহৃত হতে পারে। Return Value শুধুমাত্র ফাংশন থেকেই ফেরত দেওয়া যায়, সাবরুটিন থেকে নয়। সাবরুটিন কখনও কোনও মান ফেরত দেয় না, বরং একটি কার্যক্রম সম্পন্ন করতে ব্যবহৃত হয়।

Return Value ব্যবহার করার উদাহরণ:

Sub ExampleReturnValue()
    Dim result As Integer
    result = AddNumbers(10, 20)
    MsgBox "The sum is: " & result
End Sub

Function AddNumbers(a As Integer, b As Integer) As Integer
    AddNumbers = a + b
End Function

এখানে:

  • AddNumbers একটি ফাংশন যা দুটি ইনপুট প্যারামিটার a এবং b গ্রহণ করে এবং তাদের যোগফল ফেরত দেয়।
  • সাবরুটিন ExampleReturnValue এ ফাংশনটি কল করা হয়েছে এবং এর রিটার্ন ভ্যালু result ভেরিয়েবলে রাখা হয়েছে। আউটপুট হবে: The sum is: 30

Parameters এবং Return Values এর মধ্যে পার্থক্য

বিষয়ParametersReturn Values
প্রকারইনপুট ভ্যালু (ফাংশন বা সাবরুটিনে পাস করা হয়)আউটপুট ভ্যালু (ফাংশন থেকে ফেরত আসে)
কিভাবে ব্যবহৃত হয়ফাংশন বা সাবরুটিনে ইনপুট হিসেবে ব্যবহৃত হয়ফাংশন থেকে আউটপুট হিসেবে ফেরত দেওয়া হয়
প্যারামিটার টাইপByVal বা ByRef হিসেবে পাস করা যায়শুধুমাত্র ফাংশনে ব্যবহৃত হয়, সাবরুটিনে নয়
ফাংশন বা সাবরুটিনে ব্যবহৃতপ্যারামিটারটি ফাংশন বা সাবরুটিনের ভিতরে কাজ করার জন্য ব্যবহৃত হয়ফাংশন সম্পন্ন হওয়ার পর রিটার্ন ভ্যালু ফেরত দেওয়া হয়
উদাহরণFunction AddNumbers(a As Integer, b As Integer)Function AddNumbers(a As Integer, b As Integer) As Integer

উপসংহার

  • Parameters ফাংশন বা সাবরুটিনে ইনপুট ডেটা পাস করার জন্য ব্যবহৃত হয় এবং এটি ByVal অথবা ByRef প্যারামিটার হিসেবে হতে পারে।
  • Return Values হল ফাংশনের আউটপুট, যা ফাংশন সম্পন্ন হওয়ার পর ফেরত দেয় এবং এটি অন্য কোডে ব্যবহার করা যেতে পারে।
  • Parameters এবং Return Values ব্যবহার করে আপনি ফাংশন বা সাবরুটিনের মধ্যে ডেটা পাস এবং গ্রহণ করতে পারেন, যা কোডের পুনর্ব্যবহারযোগ্যতা এবং কার্যকারিতা বৃদ্ধি করে।
Content added By

ByRef এবং ByVal এর পার্থক্য

VBA তে ByRef এবং ByVal দুটি শব্দ প্যারামিটার পাস করার পদ্ধতি নির্দেশ করে। এই দুটি পদ্ধতির মধ্যে পার্থক্য হল, এগুলি কিভাবে আর্গুমেন্ট বা প্যারামিটারকে সাবরুটিন বা ফাংশনে পাস করা হয় এবং পাস করার পর মূল ভেরিয়েবলের মান কিভাবে পরিবর্তিত হয়।


ByVal (By Value)

  • ByVal দিয়ে একটি ভেরিয়েবল পাস করার অর্থ হল যে, ফাংশন বা সাবরুটিনে ভেরিয়েবলের একটি কপি পাঠানো হয়। এর মানে, মূল ভেরিয়েবলটি ফাংশন বা সাবরুটিনের ভিতর পরিবর্তিত হলে তার কোনো প্রভাব মূল ভেরিয়েবলে পড়ে না।
  • এটি মূল ভেরিয়েবলের একটি কপি ব্যবহার করে এবং সেই কপি ভেরিয়েবলটি ফাংশন বা সাবরুটিনের ভিতরে পরিবর্তিত হয়, কিন্তু মূল ভেরিয়েবলটি অপরিবর্তিত থাকে।

উদাহরণ:

Sub ExampleByVal()
    Dim num As Integer
    num = 10
    MsgBox "Before calling function: " & num ' 10
    Call ChangeValueByVal(num)
    MsgBox "After calling function: " & num ' 10
End Sub

Sub ChangeValueByVal(ByVal val As Integer)
    val = 20
End Sub

এখানে, num এর মান ১০ ছিল এবং ByVal প্যারামিটার হিসাবে পাস করার কারণে, ChangeValueByVal ফাংশনে val এর মান ২০ হলেও, num এর মান পরিবর্তিত হয় না। তাই, ফাংশন কল করার পর num এর মান আবারও ১০ থাকবে।


ByRef (By Reference)

  • ByRef দিয়ে একটি ভেরিয়েবল পাস করার অর্থ হল যে, ফাংশন বা সাবরুটিনে ভেরিয়েবলের সরাসরি রেফারেন্স পাঠানো হয়। এর মানে, ফাংশন বা সাবরুটিনে যদি ভেরিয়েবলের মান পরিবর্তিত হয়, তবে সেই পরিবর্তন মূল ভেরিয়েবলে প্রভাব ফেলে।
  • এটি মূল ভেরিয়েবলের অস্তিত্ব ব্যবহার করে এবং এই ভেরিয়েবলটির মান ফাংশন বা সাবরুটিনে পরিবর্তিত হলে, সেই পরিবর্তন মূল ভেরিয়েবলেও প্রতিফলিত হয়।

উদাহরণ:

Sub ExampleByRef()
    Dim num As Integer
    num = 10
    MsgBox "Before calling function: " & num ' 10
    Call ChangeValueByRef(num)
    MsgBox "After calling function: " & num ' 20
End Sub

Sub ChangeValueByRef(ByRef val As Integer)
    val = 20
End Sub

এখানে, num এর মান ১০ ছিল এবং ByRef প্যারামিটার হিসাবে পাস করার কারণে, ChangeValueByRef ফাংশনে val এর মান ২০ করার ফলে, num এর মানও পরিবর্তিত হয়ে ২০ হয়ে গেছে।


ByRef এবং ByVal এর মধ্যে প্রধান পার্থক্য

কিছু বিষয়ByValByRef
প্যারামিটার পাস করা হয়ভেরিয়েবলের একটি কপি পাস করা হয়ভেরিয়েবলের রেফারেন্স পাস করা হয়
মূল ভেরিয়েবলের মানে পরিবর্তননা, কপি পরিবর্তন হলেও মূল ভেরিয়েবলের মান পরিবর্তন হয় নাহ্যাঁ, ফাংশনে পরিবর্তিত হলে মূল ভেরিয়েবলের মানও পরিবর্তিত হয়
ব্যবহারযখন মূল ভেরিয়েবলের মান অপরিবর্তিত রাখতে চানযখন মূল ভেরিয়েবলের মান পরিবর্তন করতে চান

সারাংশ

  • ByVal: প্যারামিটার পাস করার সময় মূল ভেরিয়েবলের একটি কপি তৈরি হয় এবং ফাংশন বা সাবরুটিনের ভিতরে পরিবর্তন হলে মূল ভেরিয়েবলে কোনো প্রভাব পড়ে না।
  • ByRef: প্যারামিটার পাস করার সময় মূল ভেরিয়েবলের সরাসরি রেফারেন্স পাস হয় এবং ফাংশন বা সাবরুটিনে পরিবর্তন হলে এটি মূল ভেরিয়েবলে প্রভাব ফেলে।

এটি গুরুত্বপূর্ণ কারণ কখনো কখনো আপনি চাইবেন প্যারামিটার হিসেবে পাস করা ভেরিয়েবলের মান ফাংশনে পরিবর্তিত না হোক (তখন ByVal ব্যবহার করুন), আর কখনো আপনি চাইবেন ফাংশনে পরিবর্তিত হলে মূল ভেরিয়েবলে সেই পরিবর্তন প্রভাব ফেলুক (তখন ByRef ব্যবহার করুন)।

Content added By
Promotion

Are you sure to start over?

Loading...