برنامه نویسی در اکسل — آموزش تصویری و گام به گام

تصویر شاخص برنامه نویسی در اکسل

برنامه‌نویسی در اکسل یکی از مهارت‌های کاربردی است که می‌تواند کارایی و بهره‌وری را در محیط‌های کاری مختلف به طرز چشمگیری افزایش دهد. با استفاده از قابلیت‌های برنامه‌نویسی، کاربران می‌توانند وظایف تکراری را خودکارسازی کرده و زمان زیادی را برای انجام وظایف پیچیده‌تر ذخیره کنند. یکی از مهم‌ترین ابزارها برای انجام برنامه نویسی در اکسل، زبان Visual Basic for Applications (VBA) است که به کاربران امکان می‌دهد تا کدهای سفارشی بنویسند و عملکرد اکسل را بهبود دهند.

این مقاله به شما کمک می‌کند تا مراحل مختلف برنامه نویسی در اکسل را یاد بگیرید و با استفاده از ضبط ماکروها و نوشتن کدهای VBA، به سطح بالاتری از کارایی در استفاده از اکسل دست یابید. از فعال‌سازی تب Developer تا نوشتن کدهای سفارشی و ذخیره‌سازی آن‌ها، تمامی مراحل به صورت گام به گام توضیح داده خواهد شد.

برنامه نویسی در اکسل چیست؟

برنامه‌نویسی به نوشتن مجموعه‌ای از دستورالعمل‌ها اشاره دارد که به اکسل می‌گویند یک یا چند کار را انجام دهد. این دستورالعمل‌ها در زبان Visual Basic for Applications (VBA) نوشته می‌شوند زیرا این زبان برای اکسل قابل فهم است. برای نوشتن دستورالعمل، می‌توان کدی را در VBA نوشت یا یک ماکرو در اکسل ضبط کرد. ماکرو برای خودکارسازی کارهای تکراری ضبط می‌شود. هنگامی که یک ماکرو ضبط می‌شود، VBA کدی را در پس‌زمینه تولید می‌کند.

به عنوان مثال، برای ارسال یک گزارش اکسل، یک جدول باید هر بار مجموعه‌ای از کارهای مشابه را انجام دهد. این کارها شامل اعمال مرز، رنگ، چینش و قلم از پیش تعریف شده هستند. برای برنامه نویسی در اکسل، می‌توان یک ماکرو برای انجام تمام این کارها ضبط کرد.

هدف از برنامه نویسی در اکسل، نجات کاربر از انجام مجدد کارهای مشابه است. علاوه بر این، این کار به انجام چندین وظیفه با سرعت بالا کمک می‌کند که در صورت انجام دستی، وقت زیادی می‌برد.

VBA چیست؟

VBA (Visual Basic for Applications) زبان برنامه‌نویسی است که به‌طور خاص برای خودکارسازی و افزایش کارایی در نرم‌افزارهای مایکروسافت، از جمله اکسل، طراحی شده است. اگر شما با طریقه کد نویسی در اکسل آشنا شوید، می‌توانید به راحتی اسکریپت‌هایی بنویسید که انجام وظایف تکراری را به‌طور خودکار انجام دهند. این قابلیت به‌ویژه برای کارهای تکراری مانند فرمت‌بندی گزارش‌ها یا پردازش داده‌های زیاد مفید است.

ماکرو چیست؟

یک ماکرو در اصل یک دنباله ضبط‌شده از عملیات‌ها است که بعداً می‌توانید آن را پخش کنید. این شبیه به یک ضبط‌کننده صدا برای کارهای اکسل است. با استفاده از ماکروها، می‌توانید کارهای تکراری مانند فرمت‌بندی سلول‌ها یا به‌روزرسانی داده‌ها را به‌صورت خودکار انجام دهید.

دو روش برای ایجاد ماکرو:

  • ضبط ماکرو (بدون نیاز به کدنویسی)
  • نوشتن ماکرو با VBA (برای کنترل بیشتر)

مراحل برنامه نویسی در اکسل

برنامه‌نویسی در Excel VBA در مراحل زیر انجام می‌شود:

  1. راه اندازی محیط اکسل برای کدنویسی
  2. ضبط یک ماکرو در اکسل
  3. مشاهده و بررسی کد VBA تولید شده توسط ماکروی ضبط شده
  4. آزمایش کد VBA ماکروی ضبط شده
  5. ذخیره ماکرو ضبط شده (یا کد VBA)

در ادامه این مقاله، هر مرحله از برنامه نویسی در اکسل به طور جداگانه توضیح داده شده است. مراحل انجام هر مرحله نیز ذکر شده است.

۱– راه اندازی محیط اکسل برای کدنویسی

برای شروع کد نویسی در اکسل، لازم است محیط برنامه نویسی اکسل را راه‌اندازی کنید. این کار بسیار ساده است و با فعال‌سازی تب Developer در اکسل امکان‌پذیر است. پس از فعال‌سازی این تب، شما به ابزارهایی مانند ویرایشگر Visual Basic (VBE) و دیگر امکانات مفید دسترسی پیدا می‌کنید.

مراحل فعال‌سازی تب Developer در اکسل به شرح زیر است:

گام ۱: به تب File در نوار اکسل بروید.

تصویری از تب file در اکسل

گام ۲: گزینه Options را که در تصویر زیر نشان داده شده است، انتخاب کنید.

تصویری از اتخاب options در اکسل

گام ۳: پنجره Excel Options باز می‌شود، همانطور که در تصویر زیر نشان داده شده است. گزینه Customize Ribbon را که در سمت چپ این پنجره نمایش داده شده است، انتخاب کنید.

تصویری از انتخاب customize ribbon در اکسل

گام ۴: در بخش Choose commands from (در سمت چپ پنجره)، اطمینان حاصل کنید که Popular commands انتخاب شده باشد. در بخش Customize the ribbon (در سمت راست پنجره)، از فهرست کشویی Main Tabs را انتخاب کنید.

سپس، کادر انتخاب Developer را تیک بزنید و روی Ok کلیک کنید. این کادر انتخاب در تصویر زیر نشان داده شده است.

تصویری از انتخاب developer در اکسل

گام ۵: تب Developer در نوار اکسل ظاهر می‌شود، همانطور که در تصویر زیر نشان داده شده است.

تصویری از تب Developer در اکسل

۲– ضبط یک ماکرو در اکسل

‌می‌خواهیم یاد بگیریم چگونه یک ماکرو در اکسل ضبط کنیم. هنگامی که یک ماکرو ضبط می‌شود، تمام کارهایی که توسط کاربر (در داخل ورک‌بوک) انجام می‌شود، در ضبط‌کننده ماکرو ذخیره می‌شود تا زمانی که گزینه Stop Recording کلیک شود. علاوه بر اکسل مایکروسافت، می‌توان ماکرو را برای تمام برنامه‌های آفیس که از VBA پشتیبانی می‌کنند ضبط کرد.

مراحل ضبط یک ماکرو در اکسل به شرح زیر است:

گام ۱: از تب Developer، روی Record Macro در گروه Code کلیک کنید. همچنین می‌توان روی Record Macro از گروه Macros در تب View اکسل کلیک کرد.

تصویری از کلیک record macro برای ضبط ماکرو در اکسل

گام ۲: پنجره Record Macro باز می‌شود، همانطور که در تصویر زیر نشان داده شده است. در این پنجره، می‌توان قبل از ضبط نام ماکرو را انتخاب کرد. نام پیش‌فرض ماکرو که اکسل به آن اختصاص می‌دهد، Macro1 است.

تصویری از پنجره record macro

قوانین حاکم بر نام‌گذاری ماکرو به شرح زیر است:

  • نباید هیچ فاصله ( )، نقطه (.) یا علامت تعجب (!) داشته باشد.
  • نمی‌تواند شامل هیچ‌یک از کاراکترهای ویژه (مانند $, @, ^, #, *, &) به جز زیرخط (_) باشد.
  • نباید با یک عدد شروع شود. بلکه باید با یک حرف آغاز شود.
  • طول آن نباید از ۲۵۵ کاراکتر بیشتر باشد.

توجه: توصیه می‌شود برای ماکروها از نام‌های کوتاه و معنادار استفاده کنید. علاوه بر این، باید برای هر ماکرو یک نام منحصر به فرد اختصاص دهید. در VBA، دو ماکرو در یک ماژول کد نمی‌توانند نام یکسانی داشته باشند.

گام ۳: در کادر Macro Name، نام Recording_Macro وارد شده است.

توجه کنید که از زیرخط به عنوان جداکننده بین دو رشته (recording و macro) در نام استفاده شده است. در این نام، هیچ فضای خالی، نقطه یا کاراکتر خاصی استفاده نشده است.

تصویری از نام recording_macro

گام ۴: روی “Ok” کلیک کنید تا ضبط ماکرو شروع شود. پس از کلیک روی Ok در پنجره قبلی، دکمه Record Macro (در تب Developer یا تب View) به دکمه Stop Recording تغییر می‌کند. سپس، کارهایی که باید در ماکرو Recording_Macro ضبط شوند را انجام دهید.

توجه: از آنجا که ضبط‌کننده ماکرو هر عملیاتی که توسط کاربر انجام می‌شود را ضبط می‌کند، اطمینان حاصل کنید که عملیات در دنباله صحیحی اجرا شوند. اگر دنباله ضبط شده صحیح باشد، اکسل هر بار که ماکرو اجرا شود، کارها را به درستی انجام خواهد داد.

اما اگر خطای دنباله‌گذاری رخ دهد، باید یا کارها را دوباره ضبط کرد یا کد VBA را به صورت دستی ویرایش نمود. اگر اولین بار است که ماکرو را ضبط می‌کنید، توصیه می‌شود یک نسخه از ورک‌بوک را نگهداری کنید تا از تغییرات ناخواسته در داده‌های ذخیره شده جلوگیری شود.

در مراحل بعدی (گام‌های 4a تا 4c)، کارهایی که باید ضبط شوند انجام شده است.

  • گام 4a: سلول A1 ورق کاری را انتخاب کنید. این اولین کاری است که ضبط می‌شود. انتخاب در تصویر زیر نشان داده شده است.

تصویری از انتخاب سلول A1

  • گام 4b: عبارت Welcome to VBA را در سلول A1 تایپ کنید. این دومین کاری است که ضبط می‌شود. هنگام تایپ، علائم نقل قول ابتدایی و انتهایی را نادیده بگیرید.

تصویری از سلول A1

  • گام 4c: کلید “Enter” را فشار دهید. در نتیجه، انتخاب از سلول A1 به سلول A2 منتقل می‌شود. این سومین کاری است که ضبط می‌شود.

تصویری از انتخاب سلول A2

گام ۵: در گروه Code از تب Developer روی Stop Recording کلیک کنید. با کلیک روی این گزینه، به اکسل گفته می‌شود که از ضبط کارهای بعدی خودداری کند.

گزینه Stop Recording در تصویر زیر نشان داده شده است.

تصویری از انتخاب گزینه stop recording

۳– مشاهده و بررسی کد VBA تولید شده توسط ماکروی ضبط شده

بیایید کد VBA تولید شده توسط ماکروی ضبط شده در مرحله ۲ را مشاهده و بررسی کنیم. به یاد داشته باشید که می‌توان به طور مستقیم کدی را در ویرایشگر Visual Basic (VBE یا VB Editor) نوشت یا اجازه داد که ماکرو همین کار را انجام دهد.

VBE یک ابزار یا برنامه است که در آن کدهای VBA نوشته، ویرایش و نگهداری می‌شوند. هنگامی که یک ماکرو ضبط می‌شود، یک کد به طور خودکار در یک ماژول جدید از VBE نوشته می‌شود. توجه داشته باشید که VBA زبان برنامه‌نویسی اکسل است.

مراحل مشاهده و بررسی کد تولید شده توسط ماکروی ضبط شده به شرح زیر است:

گام ۱: از گروه Code در تب Developer روی Visual Basic کلیک کنید. این گزینه در تصویر زیر نشان داده شده است.همچنین می‌توانید کلیدهای Alt+F11 را با هم فشار دهید. این میانبر برای باز کردن پنجره VBE است.

تصویری از کلیک visual basic در اکسل

توجه: “Alt+F11” یک کلید تعویض است که با فشردن مکرر آن می‌توان بین VBE و اکسل جابجا شد.

گام ۲: پنجره ویرایشگر Visual Basic باز می‌شود، همانطور که در تصویر زیر نشان داده شده است.

در سمت چپ پنجره VBE، ورک‌شیت «worksheet»، ورک‌بوک « workbook» و ماژول‌ها «module» نمایش داده می‌شوند. این پنجره در سمت چپ (که به نام Project-VBAProject شناخته می‌شود) همچنین به عنوان پنجره پروژه یا Project Explorer در VBE شناخته می‌شود.

تصویری از پنجره Visual Basic Editor

گام ۳: روی Modules که در تصویر زیر نشان داده شده است، دوبار کلیک کنید.

توجه: Modules پوشه‌هایی هستند که پس از ضبط یک ماکرو در پنجره پروژه نمایش داده می‌شوند. این پوشه‌ها قبل از ضبط ماکرو نمایش داده نمی‌شوند. همچنین Modules زمانی نمایش داده می‌شوند که یک ماژول به صورت دستی از تب Insert در VBE وارد شود.

تصویری از کلیک روی module1

گام ۴: روی Module1 زیر Modules دوبار کلیک کنید. کدی در سمت راست پنجره VBE ظاهر می‌شود. این پنجره در سمت راست، به عنوان پنجره کد ماژول شناخته می‌شود.

کد در تصویر زیر نمایش داده شده است.

توجه: کدی که توسط ضبط ماکرو تولید می‌شود، می‌تواند در پوشه Modules (در پنجره کد ماژول) بررسی شود. در پنجره کد ماژول، همچنین می‌توان کدی را به صورت دستی نوشت یا از منبع دیگری کپی و پیست کرد.

تصویری از کد نشان داده شده در سمت راست

در مراحل بعدی (گام‌های 4a تا 4d)، کدی که توسط ماکروی ضبط شده تولید شده است، بررسی شده است.

گام 4a: اولین کلمه کد Sub است. Sub مخفف subroutine یا procedure است. در ابتدای کد، کلمه Sub، نام ماکرو (Recording_Macro) و یک جفت پرانتز خالی نمایش داده می‌شود. سپس دستوراتی که باید توسط کد اجرا شوند، دنبال می‌شود. این دستورات به شرح زیر هستند:

ActiveCell.FormulaR1C1 = “Welcome to VBA”
Range(“A2”).Select

کد با “End Sub” تمام می‌شود.

شروع یا سر و پایان یا دم کد در تصویر زیر نشان داده شده است.

تصویری از شروع و پایان کد

توجه ۱: کلمات Macro و Code اغلب توسط بسیاری از کاربران اکسل به طور معادل استفاده می‌شوند. با این حال، برخی از کاربران این دو کلمه را از یکدیگر تمایز می‌دهند.

یک کد VBA دستوری است که یا به طور مستقیم در VBE نوشته می‌شود یا توسط ضبط یک ماکرو در اکسل تولید می‌شود. در مقابل، یک ماکرو شامل دستوراتی است که کارها را در اکسل خودکار می‌کنند. با توجه به انتخاب فرد، می‌توان تصمیم گرفت که آیا بین این دو کلمه تمایز قائل شویم یا خیر.

توجه ۲: Sub می‌تواند با کلمات Private، Public، Friend یا Static همراه باشد. تمام این کلمات دامنه زیرروتین را تعیین می‌کنند. زیرروتین پیش‌فرض در VBA Public Sub است. بنابراین، وقتی Sub در یک کد نوشته می‌شود، به این معنی است که Public Sub است.

یک Public Sub می‌تواند توسط زیرروتین‌های ماژول‌های مختلف آغاز شود. اما یک Private Sub نمی‌تواند توسط زیرروتین‌های ماژول‌های دیگر آغاز شود.

گام 4b: اولین فعالیتی که انجام دادیم (در گام 4a از مرحله ۲) انتخاب سلول A1 بود. بنابراین، دستور بعدی کد به اکسل می‌گوید که سلول فعال، R1C1 است.

ActiveCell.FormulaR1C1

هنگامی که یک ماکرو ضبط می‌شود، VBA از سبک R1C1 برای ارجاع به سلول‌ها استفاده می‌کند. در این سبک، حرف R با شماره ردیف و حرف C با شماره ستون همراه است. بنابراین، سلول R1C1 به این معنی است که شماره ردیف ۱ و شماره ستون نیز ۱ است. به عبارت دیگر، سلول R1C1 معادل سلول A1 در اکسل است.

گام 4c: دومین فعالیتی که انجام دادیم (در گام 4b از مرحله ۲) تایپ عبارت Welcome to VBA در سلول A1 بود. بنابراین، دستور بعدی کد به اکسل می‌گوید که مقدار سلول R1C1 برابر با Welcome to VBA است.

ActiveCell.FormulaR1C1 = “Welcome to VBA”

گام 4d: سومین فعالیتی که انجام دادیم (در گام 4c از مرحله ۲) فشار دادن کلید Enter بود. با فشار دادن این کلید، انتخاب از سلول A1 به سلول A2 منتقل شد. بنابراین، دستور زیر به اکسل می‌گوید که سلول A2 را انتخاب کند.

Range(“A2”).Select

این روشی است که VBA برای تمام فعالیت‌هایی که در مرحله ۲ برنامه‌نویسی در اکسل انجام شده است، کد تولید می‌کند. بررسی کد خط به خط آن را آسان‌تر می‌کند.

۴– تست کد VBA ماکروی ضبط شده

بیایید کد را زمانی که چندین بار اجرا می‌شود آزمایش کنیم. توجه داشته باشید که یک ماکرو (یا کد) می‌تواند به تعداد دلخواه اجرا شود. هر بار که اجرا شود، کارهای ضبط شده را در اکسل انجام می‌دهد.

مراحل آزمایش کدی که در مرحله ۳ بررسی کردیم به شرح زیر است:

گام ۱: عبارت Welcome to VBA را از سلول A1 اکسل حذف کنید. اجازه دهید A1 به عنوان یک سلول خالی و انتخاب شده باقی بماند. تصویر زیر سلول خالی A1 را نشان می‌دهد.

توجه: برای بازگشت از VBE به اکسل، کلید تعویض Alt+F11 را فشار دهید.

تصویری از سلول خالی A1

گام ۲: دوباره به VBE بروید با فشار دادن کلید Alt+F11. در داخل کد، در هر جایی کلیک کنید. سپس، روی دکمه Run Sub/UserForm (F5) کلیک کنید. این دکمه در یک جعبه آبی در تصویر زیر نشان داده شده است.

توجه: به طور جایگزین، می‌توانید کلید F5 را برای اجرای کد VBA فشار دهید.

تصویری از کلیک روی دکمه Sub UserForm

گام ۳: خروجی در تصویر زیر نشان داده شده است. کد قبلی رشته Welcome to VBA را در سلول A1 وارد می‌کند. سپس انتخاب به سلول A2 منتقل می‌شود. رشته Welcome to VBA در سلول A1 وارد شده است زیرا این سلول قبل از اجرای کد (در گام ۱) انتخاب شده بود.

تصویری از نمایش خروجی

هر بار که کد اجرا می‌شود، سلول فعلی انتخاب شده (یا سلول فعال) با رشته Welcome to VBA پر می‌شود. سپس انتخاب به سلول A2 منتقل می‌شود. بنابراین، اگر سلول M10 سلول فعال باشد، اجرای کد این سلول را با رشته ذکر شده پر کرده و در پایان سلول A2 را انتخاب می‌کند.

با این حال، اگر سلول A2 انتخاب شده بود، اجرای کد این سلول را با رشته Welcome to VBA پر می‌کرد. علاوه بر این، در پایان، سلول A2 به عنوان سلول انتخاب شده باقی می‌ماند.

۵– ذخیره ماکروی ضبط شده در اکسل

در این بخش از مقاله یاد می‌گیریم، چگونه یک دفتر کار که شامل یک ماکرو ضبط شده است را ذخیره کنیم. اگر یک ماکرو ذخیره شود، کد VBA آن نیز ذخیره خواهد شد.

مراحل ذخیره یک دفتر کار که شامل یک ماکرو (یا کد VBA) است به شرح زیر است:

  1. روی گزینه Save As از تب فایل در اکسل کلیک کنید. کادر گفتگوی Save As باز می‌شود، همانطور که در تصویر زیر نشان داده شده است.
  2. یک نام برای دفتر کار اکسل در کادر File Name وارد کنید. ما نام macro class را وارد کرده‌ایم.
  3. دفتر کار را با پسوند xlsm. ذخیره کنید. بنابراین، در کادر Save as type، گزینه Excel Macro-Enabled Workbook را انتخاب کنید.
  4. روی “Save” کلیک کنید تا دفتر کار ذخیره شود.

یک دفتر کار که شامل ماکرو است همیشه باید با پسوند xlsm. ذخیره شود. این پسوند اطمینان حاصل می‌کند که ماکرو ذخیره می‌شود و می‌توان از آن در دفعات بعدی که دفتر کار باز می‌شود، استفاده کرد.

توجه ۱: دستور Save As زمانی استفاده می‌شود که یک دفتر کار برای اولین بار ذخیره می‌شود. همچنین زمانی که یک نسخه جدید از دفتر کار باید ایجاد شود و در عین حال نسخه اصلی حفظ شود، از این دستور استفاده می‌شود.

توجه ۲: اگر دفتر کار شامل یک ماکرو به عنوان یک دفتر کار معمولی (با پسوند xlsx.) ذخیره شود، ماکرو ذخیره نخواهد شد. علاوه بر این، ممکن است کد ماکروی ضبط شده از دست برود.

نوشتن یک ماکرو در VBA

اگر می‌خواهید کنترل بیشتری روی ماکروهای خود داشته باشید، می‌توانید آن‌ها را مستقیماً در VBA بنویسید.

ویرایشگر ویژوال بیسیک را باز کنید و یک ماژول جدید ایجاد کنید.

کد زیر را در پنجره کد وارد کنید:

Sub ChangeFontSize()
    Range("A1:A10").Font.Size = 14
End Sub

برای اجرای ماکرو، F5 را فشار دهید یا آن را به یک دکمه در اکسل اختصاص دهید.

خودکارسازی کارها با حلقه‌ها (Loops)

یکی از بهترین قابلیت‌های VBA استفاده از حلقه‌ها برای خودکارسازی وظایف تکراری است.

تصور کنید که باید صدها سلول را دستی به‌روزرسانی کنید—قطعاً خیلی زمان‌بر است. اما با استفاده از حلقه‌ها (Loops)، می‌توانید این کار را فقط در چند خط کد انجام دهید.

حلقه For در VBA

حلقه For برای اجرای یک مجموعه از عملیات‌ها تعداد مشخصی از دفعات ایده‌آل است. برای مثال، می‌توانیم از آن برای تغییر مقدار چندین سلول در یک ستون استفاده کنیم.

Sub UpdateCells()
    Dim i As Integer
    For i = 1 To 10
        Cells(i, 1).Value = "Row " & i
    Next i
End Sub

توضیح کد:

  • For i = 1 To 10: این حلقه مقدار i را از ۱ تا ۱۰ افزایش می‌دهد.
  • Cells(i, 1).Value = “Row ” & i: مقدار هر سلول در ستون A را برابر “Row 1”, “Row 2”, … قرار می‌دهد.
  • Next i: به مقدار بعدی در حلقه می‌رود.

اجرای کد: روی Run کلیک کنید یا F5 را فشار دهید—و ببینید که اکسل به‌طور خودکار مقادیر را در سلول‌های A1 تا A10 وارد می‌کند.

به‌کارگیری حلقه For در اکسل

حلقه For یک ابزار عالی برای تکرار مجموعه‌ای از عملیات بر روی چندین سلول است. به‌عنوان مثال، می‌توانیم رنگ پس‌زمینه سلول‌ها را تغییر دهیم:

Sub ColorCells()
    Dim i As Integer

    For i = 1 To 10
        Cells(i, 1).Interior.Color = RGB(255, 255, 0) 'زرد
    Next i
End Sub

توضیح کد:

حلقه For i = 1 To 10 مقدار i را از ۱ تا ۱۰ افزایش می‌دهد.

Cells(i, 1).Interior.Color = RGB(255, 255, 0) رنگ پس‌زمینه سلول‌های A1 تا A10 را زرد می‌کند.

RGB(255, 255, 0) مقدار رنگ زرد را بر اساس ترکیب قرمز، سبز و آبی (RGB) تنظیم می‌کند.

استفاده از حلقه Do While در اکسل

حلقه Do While زمانی کاربرد دارد که نمی‌دانیم تعداد دفعات تکرار دقیقا چقدر است. این حلقه تا زمانی که یک شرط برقرار باشد اجرا می‌شود.

مثال: جمع‌زدن اعداد یک ستون تا رسیدن به سلول خالی

Sub SumUntilBlank()
    Dim i As Integer
    Dim total As Double

    i = 1
    total = 0

    Do While Cells(i, 1).Value <> ""
        total = total + Cells(i, 1).Value
        i = i + 1
    Loop

    MsgBox "مجموع کل: " & total
End Sub

توضیح کد:

Do While Cells(i, 1).Value <> “” تا زمانی که سلول خالی پیدا نشود، حلقه ادامه دارد.

مقدار هر سلول در ستون A به متغیر total اضافه می‌شود.

در پایان، جمع کل در یک پیام باکس (MsgBox) نمایش داده می‌شود.

کاربرد این روش: مناسب برای مجموع‌گیری در مجموعه‌های داده‌ای که تعداد ردیف‌هایشان تغییر می‌کند.

مدیریت خطاها به‌صورت حرفه‌ای

در کدنویسی VBA، برخورد با خطاها اجتناب‌ناپذیر است. برای اینکه اسکریپت‌ها بدون متوقف شدن اجرا شوند، باید خطاها را کنترل کنیم.

مثال: مدیریت خطای تقسیم بر صفر

Sub SafeDivision()
    On Error GoTo ErrorHandler

    Dim num1 As Double
    Dim num2 As Double
    Dim result As Double

    num1 = 10
    num2 = 0 ' باعث ایجاد خطای تقسیم بر صفر می‌شود

    result = num1 / num2
    MsgBox "نتیجه: " & result
    Exit Sub

ErrorHandler:
    MsgBox "یک خطا رخ داد: " & Err.Description
End Sub

توضیح کد:

  • On Error GoTo ErrorHandler در صورت وقوع خطا، VBA را به بخش مدیریت خطا (ErrorHandler) هدایت می‌کند.
  • در حالت عادی، تقسیم بر صفر باعث توقف کد می‌شود، اما با این روش، پیام مناسب نمایش داده می‌شود.

مدیریت خطاها باعث می‌شود که برنامه شما پایدارتر باشد و از توقف ناگهانی جلوگیری شود.

ساخت توابع سفارشی در VBA

گاهی توابع پیش‌فرض اکسل کافی نیستند و نیاز به توابع سفارشی داریم. در VBA می‌توان توابع مخصوص به خود را ایجاد کرد.

مثال: محاسبه مساحت مستطیل

Function CalculateArea(length As Double, width As Double) As Double
    CalculateArea = length * width
End Function

نحوه استفاده در اکسل:

می‌توان مستقیماً این تابع را در یک سلول اکسل به‌کار برد:

type =CalculateArea(5, 10)

مزیت توابع سفارشی:

  • امکان انجام محاسبات پیچیده با استفاده از فرمول‌های ساده.
  • قابلیت بهینه‌سازی و سفارشی‌سازی اکسل بر اساس نیازهای خاص.

با ترکیب این تکنیک‌ها، می‌توانیم اکسل را به ابزاری قدرتمندتر تبدیل کنیم:

  • حلقه‌ها برای اجرای دستورات روی چندین سلول
  •  مدیریت خطاها برای جلوگیری از توقف ناگهانی کد
  • توابع سفارشی برای افزایش قابلیت‌های اکسل

ارتباط VBA با سایر برنامه‌های آفیس

یکی از ویژگی‌های قدرتمند دیگر در طریقه کد نویسی در اکسل، امکان ارتباط با سایر برنامه‌های مایکروسافت آفیس مانند Outlook است. این قابلیت به شما این امکان را می‌دهد که از اکسل برای ارسال ایمیل، ایجاد گزارش‌ها در Word و حتی استخراج داده از Access استفاده کنید. این ویژگی‌ها به‌ویژه در مواقعی که نیاز به ایجاد راه‌حل‌های یکپارچه برای کسب‌وکار دارید، مفید است.

ارسال ایمیل از اکسل با Outlook

فرض کنید می‌خواهید از اکسل یک ایمیل ارسال کنید. کافی است از VBA استفاده کنید:

Sub SendEmail()
    Dim OutlookApp As Object
    Dim Email As Object

    ' ایجاد یک نمونه از Outlook
    Set OutlookApp = CreateObject("Outlook.Application")
    Set Email = OutlookApp.CreateItem(0)

    ' تنظیم مشخصات ایمیل
    With Email
        .To = "example@example.com"
        .Subject = "Hello from Excel"
        .Body = "This is a test email sent from Excel using VBA."
        .Send ' ارسال ایمیل
    End With
End Sub

توضیح کد:

  • ابتدا یک نمونه از Outlook ایجاد می‌شود: CreateObject(“Outlook.Application”)
  • سپس یک ایمیل جدید ساخته می‌شود: Set Email = OutlookApp.CreateItem(0)
  • در بخش With Email، مشخصات ایمیل تنظیم شده و سپس با .Send ارسال می‌شود.

نکات مهم:

  • این روش نیاز به نصب Outlook دارد.
  • ممکن است بسته به تنظیمات امنیتی Outlook، نیاز به تایید ارسال ایمیل داشته باشید.
  • می‌توانید با .Display ایمیل را قبل از ارسال مشاهده کنید.

نتیجه‌گیری

در نهایت، برنامه نویسی در اکسل و استفاده از VBA به کاربران این امکان را می‌دهد تا به طور مؤثر و کارآمدتری با داده‌ها و وظایف مختلف در محیط‌های کاری خود برخورد کنند. با یادگیری ضبط ماکروها و نوشتن کدهای سفارشی، می‌توان زمان زیادی را برای انجام کارهای تکراری صرفه‌جویی کرده و به بهبود دقت و سرعت عملیات در اکسل دست یافت. این توانایی نه تنها بهره‌وری را افزایش می‌دهد، بلکه به کاربران اجازه می‌دهد تا خود را از محدودیت‌های ابزارهای استاندارد اکسل فراتر برده و راه‌حل‌های سفارشی و پیشرفته‌تری ایجاد کنند. در نتیجه، آشنایی با مراحل مختلف کد نویسی در اکسل، مانند فعال‌سازی تب Developer، ضبط ماکرو و نوشتن و ذخیره‌سازی کدهای VBA، گامی اساسی در ارتقای مهارت‌های استفاده از اکسل محسوب می‌شود.


سوالات متداول


برنامه نویسی در اکسل چیست؟

برنامه‌نویسی در اکسل به معنای دستور دادن به اکسل برای انجام یک یا چند وظیفه است. برای انجام این کار، می‌توان کدی در Visual Basic for Applications (VBA) نوشت یا یک ماکرو در اکسل ضبط کرد. هر بار که یک ماکرو ضبط می‌شود، VBA کد آن را در پس‌زمینه تولید می‌کند.

برنامه نویسی در اکسل چگونه انجام می‌شود؟

مراحل انجام برنامه نویسی در اکسل به شرح زیر است: الف. تب Developer را در اکسل فعال کنید. ب. یک ماکرو در اکسل ضبط کنید. هر فعالیت را در دنباله‌ای که باید ضبط شود انجام دهید. ج. کد تولید شده توسط ماکرو ضبط شده را ذخیره کنید و هر زمان که نیاز بود آن را اجرا کنید. همچنین می‌توان برنامه‌نویسی را با نوشتن دستی کد و سپس ذخیره و اجرای آن انجام داد.

چگونه برنامه نویسی در اکسل را یاد بگیریم؟

برای یادگیری برنامه‌نویسی، می‌توان نحوه ضبط یک ماکرو در اکسل را یاد گرفت. ضبط ماکرو راحت‌تر از نوشتن دستی کد در VBE است و حتی اگر فردی آشنایی با کدنویسی VBA نداشته باشد، می‌تواند این کار را انجام دهد. با این حال، هر بار که یک ماکرو ضبط می‌شود، کد تولید شده را با دقت بررسی کنید. هر چه بیشتر در ضبط ماکرو مهارت پیدا کنید، کدها نیز قابل درک‌تر خواهند شد. به این ترتیب، یادگیری برنامه‌نویسی در اکسل دیگر یک کار پیچیده نخواهد بود.

میزان رضایتمندی
لطفاً میزان رضایت خودتان را از این مطلب با دادن امتیاز اعلام کنید.
[ امتیاز میانگین 5 از 3 نفر ]
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع و مراجع:
مجله پی استور thebricks wallstreetmojo

دیدگاه‌ خود را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

پیمایش به بالا