Events এবং Triggers এর ব্যবহার

এক্সেল ম্যাক্রো (Excel Macros) - Big Data and Analytics

354

Events এবং Triggers Excel VBA এর অন্যতম শক্তিশালী বৈশিষ্ট্য, যা শীটের বিভিন্ন কার্যকলাপের ভিত্তিতে ম্যাক্রো অটোমেটিকভাবে চালানোর সুযোগ দেয়। এর মাধ্যমে আপনি এক্সেল শীটে কোন বিশেষ ইন্টারঅ্যাকশন বা চেঞ্জের সাথে সাথে কোড চালাতে পারেন। Events এর মাধ্যমে আপনি ব্যবহারকারীর অ্যাকশনের প্রতি সাড়া দিতে পারেন, যেমন সেল পরিবর্তন, শীটের নাম পরিবর্তন, ডেটা ইনপুট ইত্যাদি।


Event এবং Trigger এর মধ্যে পার্থক্য

  • Event: যখন শীটে কোনো নির্দিষ্ট কাজ সম্পন্ন হয় (যেমন, সেল পরিবর্তন, শীট নির্বাচন), তখন একটি ইভেন্ট ঘটতে পারে। এই ইভেন্টটি একটি নির্দিষ্ট কার্যকলাপ বা ক্রিয়াকে ট্রিগার করে।
  • Trigger: এটি সেই শর্ত যা কোনো ইভেন্টকে সক্রিয় করে তোলে। উদাহরণস্বরূপ, আপনি একটি সেলের মান পরিবর্তন করলে একটি ইভেন্ট ট্রিগার হবে, যা VBA কোড চালাবে।

Excel VBA-তে Events এর ধরন

Excel VBA তে বিভিন্ন ধরনের ইভেন্ট থাকে, যা আপনাকে শীটের ইন্টারঅ্যাকশনের ভিত্তিতে ম্যাক্রো চালাতে সহায়তা করে। এখানে কিছু গুরুত্বপূর্ণ ইভেন্টের উদাহরণ দেওয়া হলো:

১. Workbook Open এবং Workbook Close Event

এই ইভেন্টগুলো ব্যবহার করে আপনি কাজ শুরু করার সময় বা ফাইল বন্ধ করার সময় কিছু কাজ করতে পারেন।

  • Workbook Open Event: এটি সেই ইভেন্ট যা Excel ফাইলটি ওপেন হলে ট্রিগার হয়।
Private Sub Workbook_Open()
    MsgBox "Welcome to the Excel file!"
End Sub

এটি ফাইল ওপেন করার সময় "Welcome to the Excel file!" বার্তা প্রদর্শন করবে।

  • Workbook Close Event: এটি তখন ট্রিগার হয় যখন আপনি Workbook বন্ধ করেন।
Private Sub Workbook_BeforeClose(Cancel As Boolean)
    MsgBox "Goodbye! Your work is saved."
End Sub

এটি ফাইল বন্ধ করার সময় একটি বার্তা দেখাবে।

২. Sheet Change Event

এই ইভেন্টটি তখন ট্রিগার হয় যখন শীটে কোনো পরিবর্তন (যেমন সেল মান পরিবর্তন) ঘটে।

Private Sub Worksheet_Change(ByVal Target As Range)
    MsgBox "A change has occurred in the worksheet!"
End Sub

এটি শীটে যেকোনো সেল পরিবর্তন হলে একটি বার্তা দেখাবে।

৩. Selection Change Event

যখন আপনি শীটে সেল নির্বাচন পরিবর্তন করেন, তখন এটি ট্রিগার হয়।

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    MsgBox "You have selected a new cell!"
End Sub

এটি যখন আপনি শীটে নতুন সেল নির্বাচন করবেন, তখন একটি বার্তা দেখাবে।

৪. Before Save Event

ফাইল সেভ করার আগে এটি ট্রিগার হয়। আপনি এই ইভেন্ট ব্যবহার করে কিছু কাজ করতে পারেন, যেমন ফাইল সেভ করার আগে কিছু যাচাই করা।

Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean)
    MsgBox "The workbook is about to be saved."
End Sub

এটি ফাইল সেভ করার আগে একটি বার্তা দেখাবে।

৫. Workbook Sheet Activate এবং Deactivate Event

এই ইভেন্টগুলো শীটের সক্রিয় এবং নিষ্ক্রিয় হওয়ার সময় ট্রিগার হয়।

  • Sheet Activate Event: যখন শীটটি অ্যাকটিভ হয়, তখন এটি ট্রিগার হয়।
Private Sub Worksheet_Activate()
    MsgBox "This sheet is now active!"
End Sub
  • Sheet Deactivate Event: যখন শীটটি নিষ্ক্রিয় হয়, তখন এটি ট্রিগার হয়।
Private Sub Worksheet_Deactivate()
    MsgBox "This sheet is now inactive!"
End Sub

Trigger এর মাধ্যমে VBA কোড চালানো

Triggers এর মাধ্যমে আপনাকে নির্দিষ্ট শর্তের ভিত্তিতে কোড চালাতে সহায়তা করা হয়। Trigger হিসেবে বিভিন্ন ইভেন্ট ব্যবহার করা হয়, যেমন সেল পরিবর্তন, সেল নির্বাচন ইত্যাদি।

১. Cell Change Trigger

ধরা যাক, আপনি চান যে কোনো সেল পরিবর্তিত হলে কিছু কাজ শুরু হোক, যেমন সেল পরিবর্তন হলে অটোমেটিকভাবে সেই সেলের মান ২ গুণ হয়ে যাক।

Private Sub Worksheet_Change(ByVal Target As Range)
    If Not Intersect(Target, Range("A1")) Is Nothing Then
        Target.Value = Target.Value * 2
    End If
End Sub

এটি যখন A1 সেল পরিবর্তিত হবে, তখন সেলের মান ২ গুণ হয়ে যাবে।

২. Selection Change Trigger

আপনি যদি চান যে, শীটে কোনো সেল নির্বাচন পরিবর্তন হলে একটি নির্দিষ্ট কাজ শুরু হোক, তাহলে এই ধরনের কোড ব্যবহার করতে পারেন।

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    If Not Intersect(Target, Range("B1:B10")) Is Nothing Then
        MsgBox "You selected a cell in B1 to B10 range."
    End If
End Sub

এটি যখন আপনি B1:B10 রেঞ্জের কোনো সেল নির্বাচন করবেন, তখন একটি বার্তা দেখাবে।

৩. Workbook Open Trigger

ধরা যাক, আপনি যখন কোনো এক্সেল ফাইল ওপেন করবেন তখন কিছু ম্যাক্রো রান করতে চান।

Private Sub Workbook_Open()
    MsgBox "This file is now open. Let's get started!"
End Sub

এটি ফাইল ওপেন করার সময় একটি বার্তা দেখাবে।


Events এবং Triggers ব্যবহার করার উপকারিতা

  • অটোমেশন: Excel শীটে বিভিন্ন ইভেন্টের মাধ্যমে কাজ অটোমেট করা যায়, যেমন ফাইল ওপেন করলে বা সেল পরিবর্তিত হলে কোড স্বয়ংক্রিয়ভাবে চালানো।
  • ইন্টারঅ্যাকটিভ কার্যক্রম: ব্যবহারকারীর কার্যকলাপের ভিত্তিতে ইভেন্ট ট্রিগার করা, যেমন সেল পরিবর্তন বা শীট সক্রিয় হওয়া, আপনাকে আরও ইন্টারঅ্যাকটিভ সিস্টেম তৈরি করতে সাহায্য করে।
  • ডেটা যাচাই এবং প্রসেসিং: আপনি কোনো ডেটার মান পরিবর্তন হলে তা স্বয়ংক্রিয়ভাবে যাচাই করতে পারেন এবং প্রক্রিয়াকরণ করতে পারেন।

সারাংশ

Excel VBA তে Events এবং Triggers ব্যবহার করে আপনি শীটে ঘটিত নানা পরিবর্তন বা ব্যবহারকারীর কাজের ভিত্তিতে অটোমেটিক কোড চালাতে পারেন। Event হলো সেই ঘটনা যা এক্সেল শীটে ঘটে এবং Trigger হলো সেই শর্ত যা ইভেন্টটিকে চালু করে। Workbook_Open, Worksheet_Change, SelectionChange ইত্যাদি ইভেন্টের মাধ্যমে আপনার Excel শীটের কার্যকলাপের সাথে ম্যাক্রোকে অটোমেট করা সম্ভব। এর মাধ্যমে আপনার কাজের গতি ও দক্ষতা বাড়ানো যায়।

Content added By

Workbook এবং Worksheet Events (Open, Close, Activate)

362

Workbook এবং Worksheet Events ব্যবহার করে আপনি Excel এর বিভিন্ন কার্যক্রমের উপর নজর রাখতে এবং সেগুলি অনুযায়ী স্বয়ংক্রিয়ভাবে কোড চালাতে পারেন। এই ইভেন্টগুলি এমন কার্যক্রম বা পরিবর্তনগুলির জন্য ট্রিগার হয় যা এক্সেল ফাইলের মধ্যে ঘটে, যেমন: ফাইল খোলা (Open), ফাইল বন্ধ করা (Close), শীট সক্রিয় করা (Activate), ইত্যাদি। VBA ব্যবহার করে আপনি এসব ইভেন্টের জন্য স্বয়ংক্রিয় কোড সেট করতে পারেন, যা নির্দিষ্ট সময়ে স্বয়ংক্রিয়ভাবে কার্যকরী হবে।


Workbook Events

Workbook Events হল এমন ইভেন্টগুলি যা পুরো Workbook এর ওপর কার্যকর হয়। এগুলো সাধারণত Workbook এর অবস্থান বা অবস্থায় পরিবর্তন হলে ট্রিগার হয়, যেমন Workbook খোলা, বন্ধ করা বা সংরক্ষণ করা ইত্যাদি।

১. Workbook Open Event

এই ইভেন্টটি তখন ট্রিগার হয় যখন একটি Workbook খোলা হয়। এটি ব্যবহার করে আপনি ফাইল ওপেন করার সময় কোনো নির্দিষ্ট কোড চালাতে পারেন।

কোড উদাহরণ:

Private Sub Workbook_Open()
    MsgBox "Welcome to the Workbook!"
End Sub

এই কোডটি Workbook খোলার সময় একটি স্বাগত বার্তা প্রদর্শন করবে।

২. Workbook Close Event

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

কোড উদাহরণ:

Private Sub Workbook_BeforeClose(Cancel As Boolean)
    Dim response As Integer
    response = MsgBox("Do you want to save changes?", vbYesNoCancel)
    If response = vbYes Then
        ThisWorkbook.Save
    ElseIf response = vbNo Then
        ThisWorkbook.Saved = True
    Else
        Cancel = True
    End If
End Sub

এটি ফাইল বন্ধ করার আগে একটি পপ-আপ বার্তা দেখাবে এবং ইউজারকে পরিবর্তনগুলি সেভ করতে, না করতে বা বন্ধের প্রক্রিয়া বাতিল করতে বলবে।

৩. Workbook Activate Event

এই ইভেন্টটি তখন ট্রিগার হয় যখন Workbook সক্রিয় হয় (অর্থাৎ, যখন এটি নির্বাচন করা হয় এবং এটি অন্য কোনো উইন্ডো থেকে সামনে চলে আসে)।

কোড উদাহরণ:

Private Sub Workbook_Activate()
    MsgBox "You have activated this workbook."
End Sub

এই কোডটি Workbook সক্রিয় হলে একটি বার্তা প্রদর্শন করবে।

৪. Workbook Deactivate Event

এই ইভেন্টটি তখন ট্রিগার হয় যখন Workbook এর ফোকাস অন্য কোনো Workbook বা অ্যাপ্লিকেশন এ চলে যায়। আপনি এই ইভেন্ট ব্যবহার করে কর্মপদ্ধতি শেষ করার আগে কিছু কাজ করতে পারেন।

কোড উদাহরণ:

Private Sub Workbook_Deactivate()
    MsgBox "You have deactivated this workbook."
End Sub

এটি Workbook এর ফোকাস অন্য কোথাও চলে গেলে একটি বার্তা দেখাবে।


Worksheet Events

Worksheet Events হল এমন ইভেন্টগুলি যা নির্দিষ্ট Worksheet এর ওপর কার্যকর হয়। এগুলি তখন ট্রিগার হয় যখন শীটে কোনো পরিবর্তন ঘটে, যেমন শীট একটিভেট হওয়া, সেল নির্বাচন হওয়া, অথবা কোনো ডেটা পরিবর্তন হওয়া।

১. Worksheet Activate Event

এই ইভেন্টটি তখন ট্রিগার হয় যখন একটি Worksheet সক্রিয় হয় (অর্থাৎ, শীটটি নির্বাচিত হয় এবং অন্য শীট থেকে ফোকাস চলে আসে)।

কোড উদাহরণ:

Private Sub Worksheet_Activate()
    MsgBox "You have activated this worksheet."
End Sub

এটি শীটটি একটিভ হলে একটি বার্তা দেখাবে।

২. Worksheet Deactivate Event

এই ইভেন্টটি তখন ট্রিগার হয় যখন একটি Worksheet এর ফোকাস অন্য Worksheet-এ চলে যায়।

কোড উদাহরণ:

Private Sub Worksheet_Deactivate()
    MsgBox "You have deactivated this worksheet."
End Sub

এটি শীটটি ডিসঅ্যাকটিভ হলে একটি বার্তা দেখাবে।

৩. Worksheet Change Event

এই ইভেন্টটি তখন ট্রিগার হয় যখন শীটের কোনো সেলে পরিবর্তন করা হয়। এটি সেলগুলির ডেটা পরিবর্তন বা নতুন ডেটা এন্ট্রি করার পর কার্যকরী হয়।

কোড উদাহরণ:

Private Sub Worksheet_Change(ByVal Target As Range)
    MsgBox "Cell " & Target.Address & " has been changed."
End Sub

এটি সেল পরিবর্তন হওয়ার সাথে সাথে সেলটির ঠিকানা সহ একটি বার্তা প্রদর্শন করবে।

৪. Worksheet Calculate Event

এই ইভেন্টটি তখন ট্রিগার হয় যখন Worksheet এ কোনো গণনা (calculation) হয়। এটি সাধারণত তখন ঘটে যখন কোনো ফর্মুলা রিফ্রেশ বা পুনরায় হিসাব করা হয়।

কোড উদাহরণ:

Private Sub Worksheet_Calculate()
    MsgBox "Worksheet calculation is complete."
End Sub

এটি শীটের গণনা শেষ হলে একটি বার্তা দেখাবে।

৫. Worksheet Selection Change Event

এই ইভেন্টটি তখন ট্রিগার হয় যখন শীটে কোনো সেল নির্বাচন পরিবর্তন হয়।

কোড উদাহরণ:

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    MsgBox "You selected " & Target.Address
End Sub

এটি যখনই সেল নির্বাচন পরিবর্তন হবে, তখন সেলটির ঠিকানা সহ একটি বার্তা দেখাবে।


Workbook এবং Worksheet Event ব্যবহার করার সুবিধা

১. স্বয়ংক্রিয় কাজ

Workbook এবং Worksheet Events ব্যবহার করে আপনি বিভিন্ন কার্যক্রম স্বয়ংক্রিয়ভাবে চালাতে পারেন। যেমন, ফাইল খোলার পর স্বাগত বার্তা, সেল পরিবর্তন হলে গণনা শুরু, শীট পরিবর্তন হলে বিশেষ নির্দেশনা ইত্যাদি।

২. কাস্টমাইজড আচরণ

আপনার প্রয়োজন অনুযায়ী Excel এর আচরণ কাস্টমাইজ করতে পারেন। উদাহরণস্বরূপ, ফাইল বন্ধ করার আগে কোনো চেক পরিচালনা করা, বা শীট পরিবর্তন হলে কিছু নির্দিষ্ট কাজ করা।

৩. ডেটা সুরক্ষা এবং চেকিং

Worksheet Change ইভেন্ট ব্যবহার করে আপনি সেলে ভুল বা অবাঞ্ছিত ডেটা এন্ট্রি হওয়া রোধ করতে পারেন। যেমন, নির্দিষ্ট পরিসরে মান রাখার জন্য সতর্কীকরণ বার্তা প্রদর্শন করা।

৪. ইউজার ফ্রেন্ডলি

এই ইভেন্টগুলো ব্যবহার করে আপনি ইউজারদের জন্য আরও ইন্টারঅ্যাকটিভ এবং ইউজার-ফ্রেন্ডলি এক্সেল ফাইল তৈরি করতে পারেন। এগুলো তাদের কাজের গতি বাড়াতে এবং কাজের কার্যকারিতা নিশ্চিত করতে সহায়তা করে।


সারাংশ

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

Content added By

Change Event দিয়ে Dynamic Response তৈরি করা

340

Change Event একটি গুরুত্বপূর্ণ VBA ইভেন্ট, যা এক্সেল শীটের কোনো সেলে পরিবর্তন ঘটলে ট্রিগার হয়। এর মাধ্যমে আপনি ডাইনামিক ফাংশনালিটি তৈরি করতে পারেন, যেমন সেল ভ্যালু পরিবর্তন হলে অটোমেটিকভাবে অন্য কোনো কাজ করা বা সেলগুলোর মান অনুসারে কিছু পরিবর্তন করা।

Change Event ব্যবহার করে আপনি শীটের নির্দিষ্ট সেল বা রেঞ্জের পরিবর্তনের ভিত্তিতে কোড চালাতে পারেন, যা অটোমেটেড কার্যক্রম এবং ডাইনামিক রেসপন্স তৈরি করতে সহায়ক।


Change Event এর মৌলিক ধারণা

Change Event তখনই ট্রিগার হয় যখন শীটে কোনো সেলে ডেটা পরিবর্তিত হয়, যেমন সেল এ কিছু লেখা হলে বা কোনো সংখ্যা পরিবর্তিত হলে। এটি আপনাকে সেল পরিবর্তন হতে দেখিয়ে সেই অনুযায়ী প্রোগ্রাম চালানোর সুযোগ দেয়।

উদাহরণ:

  • যদি কোনো নির্দিষ্ট সেল পরিবর্তিত হয়, তখন অন্য সেলে মান সেট করা।
  • সেলটির মান নির্দিষ্ট শর্ত পূর্ণ করলে একটি বার্তা প্রদর্শন করা।
  • সেল গুলি অটোমেটিক ফরম্যাট করা যখন কোনো পরিবর্তন ঘটে।

Change Event ব্যবহারের জন্য কোড লেখা

Change Event কোডটি আপনাকে VBA এ Worksheet মডিউলে লিখতে হবে। এটি শীটে কোনো সেল বা রেঞ্জে পরিবর্তন ঘটলে স্বয়ংক্রিয়ভাবে ট্রিগার হবে।

উদাহরণ ১: একটি সেলের মান পরিবর্তিত হলে অন্য সেলে মান সেট করা

Private Sub Worksheet_Change(ByVal Target As Range)
    ' যদি A1 সেলে পরিবর্তন হয়
    If Not Intersect(Target, Me.Range("A1")) Is Nothing Then
        ' তখন B1 সেলে একটি নতুন মান লিখে দিন
        Me.Range("B1").Value = "Value Changed"
    End If
End Sub

এটি A1 সেলে যেকোনো পরিবর্তন হলে B1 সেলে "Value Changed" লেখা হবে।

ব্যাখ্যা:

  • Worksheet_Change: এটি একটি ইভেন্ট সাবরুটিন যা শীটের সেলে পরিবর্তন ঘটলে চালানো হয়।
  • Target: এটি সেল বা রেঞ্জকে নির্দেশ করে যেখানে পরিবর্তন হয়েছে।
  • Intersect: এটি চেক করে যে পরিবর্তনটি A1 সেলে ঘটেছে কিনা।
  • Me.Range("B1").Value: B1 সেলের মান পরিবর্তন করে "Value Changed" সেট করা।

উদাহরণ ২: সেল গুলোর মধ্যে নির্দিষ্ট মান পরিবর্তন হলে সেল ফরম্যাট করা

Private Sub Worksheet_Change(ByVal Target As Range)
    ' যদি A1 সেলে মান 100 এর বেশি হয়
    If Not Intersect(Target, Me.Range("A1")) Is Nothing Then
        If Me.Range("A1").Value > 100 Then
            ' A1 সেলটি সবুজ রঙে পরিবর্তন হবে
            Me.Range("A1").Interior.Color = RGB(0, 255, 0)
        Else
            ' যদি A1 এর মান 100 এর কম হয়, তবে সেলটি লাল রঙে পরিবর্তন হবে
            Me.Range("A1").Interior.Color = RGB(255, 0, 0)
        End If
    End If
End Sub

এটি A1 সেলের মান 100 এর বেশি হলে সেই সেলটিকে সবুজ (Green) রঙে পরিবর্তন করবে, অন্যথায় লাল (Red) রঙে।

ব্যাখ্যা:

  • If Me.Range("A1").Value > 100: এই শর্তে A1 সেলের মান যাচাই করা হচ্ছে। যদি মান 100 এর বেশি হয়, তবে সেলটির রঙ সবুজ হবে।
  • RGB(0, 255, 0): এই ফাংশনটি সবুজ রঙের জন্য কোড।

উদাহরণ ৩: রেঞ্জের মধ্যে পরিবর্তন হলে একটি বার্তা প্রদর্শন করা

Private Sub Worksheet_Change(ByVal Target As Range)
    ' যদি A1 থেকে A5 রেঞ্জের মধ্যে কোন পরিবর্তন হয়
    If Not Intersect(Target, Me.Range("A1:A5")) Is Nothing Then
        MsgBox "A1 থেকে A5 রেঞ্জে কিছু পরিবর্তন হয়েছে!"
    End If
End Sub

এটি A1:A5 রেঞ্জের মধ্যে কোনো পরিবর্তন ঘটলে একটি ম্যাসেজ বক্সে বার্তা দেখাবে।

ব্যাখ্যা:

  • Me.Range("A1:A5"): এটি A1 থেকে A5 রেঞ্জের মধ্যে পরিবর্তন চেক করছে।
  • MsgBox: একটি বার্তা বাক্স প্রদর্শন করবে।

Change Event এ Multiple Cells এবং Specific Conditions Handling

আপনি একাধিক সেল বা নির্দিষ্ট শর্ত যোগ করে বিভিন্ন ধরনের কার্যক্রম চালাতে পারেন।

উদাহরণ ৪: সেল পরিবর্তনের ভিত্তিতে একাধিক সেলে পরিবর্তন করা

Private Sub Worksheet_Change(ByVal Target As Range)
    ' যদি A1 থেকে A3 রেঞ্জে কোন পরিবর্তন হয়
    If Not Intersect(Target, Me.Range("A1:A3")) Is Nothing Then
        ' A1 থেকে A3 সেলগুলোর মান "Updated" লেখা হবে
        Me.Range("A1:A3").Value = "Updated"
    End If
End Sub

এটি A1:A3 রেঞ্জে কোনো পরিবর্তন হলে সেই সেলগুলোতে "Updated" লেখা হবে।


সারাংশ

Change Event আপনাকে Excel শীটে ডাইনামিক রেসপন্স তৈরি করতে সাহায্য করে। আপনি নির্দিষ্ট সেল বা রেঞ্জে পরিবর্তন হলে অটোমেটিকভাবে কোড চালানোর সুযোগ পান, যা বিভিন্ন কার্যক্রম যেমন ডেটা আপডেট, সেল ফরম্যাটিং, বার্তা প্রদর্শন ইত্যাদি সম্পাদন করতে ব্যবহৃত হয়। Worksheet_Change ইভেন্ট ব্যবহার করে একাধিক শীটে কাজের গতি ও কার্যকারিতা বাড়ানো যায়, বিশেষ করে যখন আপনাকে ব্যবহারকারীর ইনপুটের ভিত্তিতে স্বয়ংক্রিয় প্রতিক্রিয়া তৈরি করতে হয়।

Content added By

Button Click এবং User Form Interaction এর জন্য Events

319

Excel Macros ব্যবহার করে আপনি Button Click এবং User Form Interaction এর মাধ্যমে ইন্টারঅ্যাকটিভ এক্সেল অ্যাপ্লিকেশন তৈরি করতে পারেন। Events হল এমন কার্যক্রম, যা কোনো নির্দিষ্ট ঘটনা বা ব্যবহারকারীর ক্রিয়ার ভিত্তিতে ট্রিগার হয়। যেমন, একটি Button ক্লিক করলে অথবা User Form-এ কিছু ইনপুট দিলে কিছু নির্দিষ্ট কাজ সম্পন্ন হয়। VBA (Visual Basic for Applications) কোড ব্যবহার করে আপনি এই ধরনের Events পরিচালনা করতে পারেন।


Excel VBA Events এর সাথে Button Interaction

Button ক্লিক করার জন্য Excel-এ ActiveX Control অথবা Form Control বাটন ব্যবহার করা হয়। যখন আপনি এই বাটনে ক্লিক করেন, তখন VBA Event এর মাধ্যমে নির্দিষ্ট কার্যক্রম শুরু হয়।

১. Button Add করা

প্রথমে, একটি Button যোগ করা প্রয়োজন। এখানে, Form Control বাটন ব্যবহার করার পদ্ধতি দেখানো হচ্ছে:

  1. Developer Tab থেকে Insert ক্লিক করুন।
  2. Form Controls এর মধ্যে Button (Form Control) নির্বাচন করুন।
  3. যেখানে আপনি বাটনটি রাখতে চান, সেখানে ক্লিক করুন।
  4. এবার, একটি ডায়ালগ বক্স আসবে যেখানে আপনি বাটনের জন্য একটি ম্যাক্রো নির্বাচন করতে পারবেন বা নতুন একটি ম্যাক্রো তৈরি করতে পারবেন।

২. Button Click Event

Button ক্লিক হলে একটি নির্দিষ্ট কাজ সম্পন্ন করার জন্য, আপনাকে VBA কোডের মধ্যে Button Click Event তৈরি করতে হবে। নিচে একটি উদাহরণ দেওয়া হলো:

Sub ButtonClickEvent()
    MsgBox "Button Clicked!"
End Sub

এটি ব্যবহার করার পর, বাটনে ক্লিক করলে একটি Message Box প্রদর্শিত হবে, যেখানে লেখা থাকবে "Button Clicked!"

৩. Button এর মাধ্যমে Range পরিবর্তন করা

ধরা যাক, আপনি একটি Button ক্লিক করলে একাধিক সেলের মান পরিবর্তন করতে চান। এটি করার জন্য নিচের কোডটি ব্যবহার করা যেতে পারে:

Sub ChangeRangeValues()
    Range("A1").Value = "Hello"
    Range("A2").Value = "World"
End Sub

এখানে, বাটন ক্লিক করলে A1 সেলে "Hello" এবং A2 সেলে "World" লেখা হবে।


User Form Interaction এর জন্য Events

User Forms হল এক্সেলে গ্রাফিক্যাল ইউজার ইন্টারফেস (GUI) তৈরি করার জন্য ব্যবহৃত একটি টুল, যার মাধ্যমে ব্যবহারকারী ইনপুট নিতে এবং ফলাফল প্রদর্শন করতে পারে। User Form এর জন্য কিছু সাধারণ Events হল: Initialize, Click, Change, Submit, ইত্যাদি।

১. User Form তৈরি করা

প্রথমে, User Form তৈরি করতে হবে:

  1. VBA Editor খুলুন (Alt + F11)।
  2. Insert মেনু থেকে UserForm নির্বাচন করুন।
  3. ফর্মে বিভিন্ন Controls (যেমন TextBox, Button, Label) যোগ করুন।

২. UserForm Initialization (Initialize Event)

যখন UserForm ওপেন হয়, তখন কিছু নির্দিষ্ট কাজ করার জন্য Initialize ইভেন্ট ব্যবহার করা হয়। উদাহরণস্বরূপ, ফর্মের লেবেলটি "Enter Details" হিসেবে সেট করতে:

Private Sub UserForm_Initialize()
    Label1.Caption = "Enter Details"
End Sub

এখানে, যখন UserForm ওপেন হবে, তখন Label1 এর ক্যাপশন হবে "Enter Details"

৩. Button Click Event in User Form

একটি Button ক্লিক করলে UserForm-এ কিছু কাজ করার জন্য কোড দেওয়া যেতে পারে। নিচের উদাহরণে, যখন Submit Button ক্লিক করা হবে, তখন TextBox-এর মান Message Box-এ প্রদর্শিত হবে:

Private Sub SubmitButton_Click()
    MsgBox "Entered Name: " & TextBox1.Value
End Sub

এখানে, যখন SubmitButton ক্লিক করা হবে, তখন TextBox1 এর ইনপুট মান একটি Message Box-এ প্রদর্শিত হবে।

৪. TextBox Change Event

TextBox-এ কোনো ইনপুট পরিবর্তিত হলে, আপনি একটি Change ইভেন্ট ব্যবহার করতে পারেন। যেমন, একটি TextBox তে মান পরিবর্তন হলে তাতে Label আপডেট করা:

Private Sub TextBox1_Change()
    Label2.Caption = "You typed: " & TextBox1.Value
End Sub

এখানে, যখন TextBox1-এ কোনো মান টাইপ করা হবে, তখন Label2 এর ক্যাপশন আপডেট হবে।


বিভিন্ন ধরনের UserForm Events

১. Click Event

Click ইভেন্ট ব্যবহার করে আপনি ফর্মের মধ্যে কোনো বোতাম বা অন্য কোনো উপাদান ক্লিক করলে একটি কার্য সম্পাদন করতে পারেন। উদাহরণ:

Private Sub Button1_Click()
    MsgBox "Button clicked"
End Sub

২. KeyPress Event

KeyPress ইভেন্ট ব্যবহার করে আপনি ফর্মে বা কন্ট্রোলের মধ্যে কী চাপলে কিছু কাজ করতে পারেন। উদাহরণ:

Private Sub TextBox1_KeyPress(KeyAscii As Integer)
    If KeyAscii = 13 Then ' Enter key pressed
        MsgBox "You pressed Enter!"
    End If
End Sub

এখানে, TextBox1-এ Enter কী চাপলে একটি Message Box প্রদর্শিত হবে।

৩. ComboBox Change Event

ComboBox এর মান পরিবর্তিত হলে এটি একটি Change ইভেন্ট ট্রিগার করে। যেমন:

Private Sub ComboBox1_Change()
    MsgBox "Selected Item: " & ComboBox1.Value
End Sub

এখানে, ComboBox1-এ কোনো মান পরিবর্তন হলে তা Message Box-এ দেখানো হবে।


Button এবং UserForm Interaction এর উদাহরণ

ধরা যাক, আপনি একটি UserForm তৈরি করেছেন যার মধ্যে একটি TextBox এবং একটি Button রয়েছে। আপনি চান যে, ব্যবহারকারী Button ক্লিক করলে TextBox-এর মান একটি নির্দিষ্ট সেলে লেখা হবে।

Private Sub CommandButton1_Click()
    ' TextBox এর মান A1 সেলে লেখা
    Range("A1").Value = TextBox1.Value
    ' ফর্ম বন্ধ করা
    Unload Me
End Sub

এখানে, যখন CommandButton1 ক্লিক করা হবে, তখন TextBox1 এর মান A1 সেলে লেখা হবে এবং তারপর UserForm বন্ধ হবে।


সারাংশ

Button Click এবং UserForm Interaction এর মাধ্যমে আপনি Excel Macros এ ইন্টারঅ্যাকটিভ কার্যক্রম তৈরি করতে পারেন। Events হল নির্দিষ্ট কার্যক্রম যা ব্যবহারকারীর ক্রিয়া বা অন্য কোনো ঘটনা ঘটলে ট্রিগার হয়। আপনি Button ক্লিক, TextBox পরিবর্তন, ComboBox নির্বাচন ইত্যাদির মাধ্যমে বিভিন্ন কার্য সম্পাদন করতে পারবেন। VBA Events ব্যবহার করে আপনি এক্সেলের বিভিন্ন কন্ট্রোলের মধ্যে স্বয়ংক্রিয় কাজ পরিচালনা করতে পারেন, যা Excel-কে আরও শক্তিশালী ও ব্যবহারবান্ধব করে তোলে।

Content added By

Custom Event তৈরি এবং ব্যবহার

351

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


Custom Event কী?

একটি Custom Event হলো একটি কাস্টম ট্রিগার বা সিগন্যাল যা আপনি নিজের কোডে তৈরি করে যখনই কোনো নির্দিষ্ট শর্ত পূর্ণ হয়, তখন একে একটিভেট করা হয়। এক্সেল VBA-তে Event Handling সাধারণত Workbook, Worksheet, বা UserForm-এ নির্দিষ্ট কিছু ইভেন্টের জন্য ব্যবহৃত হয় (যেমন, সেল পরিবর্তন, ওয়র্কবুক ওপেন করা)। তবে, আপনি নিজের ইভেন্টও তৈরি করতে পারেন।


Custom Event তৈরি করা

Custom Event তৈরি করার জন্য আপনাকে একটি ক্লাস মডিউল (Class Module) ব্যবহার করতে হবে। এটি ইভেন্ট তৈরি এবং সেগুলোর জন্য হ্যান্ডলার সেটআপ করতে সাহায্য করে।

১. ক্লাস মডিউল তৈরি করা

প্রথমে একটি ক্লাস মডিউল তৈরি করুন, যেখানে আপনি আপনার Custom Event লিখবেন। উদাহরণস্বরূপ, একটি ButtonClicked ইভেন্ট তৈরি করা।

  1. VBA Editor-এ ক্লাস মডিউল যোগ করুন:
    • Insert > Class Module নির্বাচন করুন।
    • ক্লাস মডিউলের নাম দিন, যেমন EventClass.
  2. ক্লাস মডিউলে নিচের কোডটি লিখুন:
' EventClass.cls
Public Event ButtonClicked()

Public Sub TriggerButtonClick()
    RaiseEvent ButtonClicked
End Sub

ব্যাখ্যা:

  • Event ButtonClicked: এটি একটি কাস্টম ইভেন্ট তৈরি করেছে।
  • Sub TriggerButtonClick: এই সাবরুটিনটি ইভেন্টটি ট্রিগার করবে যখন এই সাবটি কল করা হবে।

Custom Event ব্যবহার করা

একবার আপনি একটি কাস্টম ইভেন্ট তৈরি করলে, তখন এটি ব্যবহার করতে হবে। এজন্য একটি Standard Module থেকে এই ইভেন্টটি কল করা হয় এবং হ্যান্ডল করা হয়।

২. Standard Module তৈরি করা

  1. VBA Editor-এ একটি Standard Module যোগ করুন:
    • Insert > Module নির্বাচন করুন।
  2. মডিউলে নিচের কোডটি লিখুন:
' Standard Module
Dim WithEvents obj As EventClass

Sub InitializeEvent()
    Set obj = New EventClass
    obj.TriggerButtonClick
End Sub

Private Sub obj_ButtonClicked()
    MsgBox "Button Clicked Event Triggered!"
End Sub

ব্যাখ্যা:

  • Dim WithEvents obj As EventClass: WithEvents কিওয়ার্ডটি ব্যবহার করে obj নামের একটি অবজেক্ট তৈরি করা হয়েছে, যা EventClass ক্লাসের ইভেন্টের সাথে যুক্ত।
  • Sub InitializeEvent: এই সাবটিতে কাস্টম ইভেন্টটি ইনিশিয়ালাইজ করা হচ্ছে এবং TriggerButtonClick সাবকে কল করা হচ্ছে, যা ইভেন্টটি ট্রিগার করবে।
  • Private Sub obj_ButtonClicked: এখানে কাস্টম ইভেন্টের হ্যান্ডলার লেখা হয়েছে, যা ButtonClicked ইভেন্ট ট্রিগার হলে চালু হবে এবং একটি মেসেজ বক্স দেখাবে।

Custom Event ট্রিগার করা

এখন আপনি InitializeEvent সাবটিকে চালিয়ে কাস্টম ইভেন্ট ButtonClicked ট্রিগার করতে পারেন। যেমন, কোড চালানোর পর একটি মেসেজ বক্স পপ-আপ হবে "Button Clicked Event Triggered!"।

৩. Custom Event Call এবং Execute

Sub TestCustomEvent()
    InitializeEvent
End Sub

এটি TestCustomEvent সাবটি চালালে ButtonClicked ইভেন্ট ট্রিগার করবে এবং আপনার নির্ধারিত কার্যক্রম (এখানে মেসেজ বক্স) চালু করবে।


Custom Event এর ব্যবহার

  1. Custom Notifications: আপনি নির্দিষ্ট শর্ত পূর্ণ হলে নোটিফিকেশন প্রদানের জন্য কাস্টম ইভেন্ট তৈরি করতে পারেন।
  2. Data Validation: যখন কোনো নির্দিষ্ট ডেটা শীটে পরিবর্তিত হয়, তখন কাস্টম ইভেন্ট ট্রিগার করা হতে পারে।
  3. User Interaction: ইউজার যদি কোনো নির্দিষ্ট অ্যাকশন নেয়, যেমন একটি বাটন ক্লিক, তখন কাস্টম ইভেন্ট ব্যবহার করা যেতে পারে।

সারাংশ

Custom Events এক্সেল ম্যাক্রো প্রোগ্রামিং-এ খুবই শক্তিশালী একটি বৈশিষ্ট্য যা আপনাকে আপনার নির্দিষ্ট প্রয়োজনে কাস্টম ইভেন্ট তৈরি এবং ট্রিগার করতে সাহায্য করে। এটি কোডের মধ্যে নির্দিষ্ট কার্যক্রমের জন্য ইভেন্ট ব্যবহার করতে সক্ষম করে, যা আপনার অটোমেশনকে আরও উন্নত এবং কার্যকরী করে তোলে। VBA ক্লাস মডিউল এবং Standard Module এর সমন্বয়ে কাস্টম ইভেন্ট তৈরি এবং ব্যবহার করা সম্ভব, যা আপনার এক্সেল অ্যাপ্লিকেশনকে আরও বেশি ইন্টারেকটিভ এবং অটোমেটেড করতে সহায়ক।

Content added By
Promotion

Are you sure to start over?

Loading...