ایجاد حلقه های تکرار در VBA اکسل با ساختار For
انجام کارهای تکراری در اکسل با حلقه ها در ماکرو
یکی از مهمترین مزایای استفاده از وی بی (VBA) در اکسل امکان تکرار کدها به تعداد دلخواه هست. این کار با استفاده از ساختارهایی به نام حلقه انجام پذیر هستند. در زبان VBA چندین نوع حلقه وجود دارد. در این آموزش قصد داریم ساختار دستوری حلقه For رو آموزش بدم. یکی از ساختارهای حلقه ها در ماکرو ، حلقه For برای اجرای کدهای نوشته شده به تعداد از پیش تعیین شده هست. یعنی فرض کنید شما قصد دارید نام شیت های فایل رو در سلول ها بنویسید. در این حالت مشخص است که به تعداد شیت های موجود باید کدها اجرا شوند.
حالت دیگر حلقه ها زمانی هست که شما از ابتدا دقیق نمیدانید که کدهای مدنظر شما چند بار باید تکرار شود و در واقع تکرار کدها مشروط به شرایط خاصی هست.
به صورت کلی حلقه For دارای دو ساختار هست:
- ساختار For … Next
- ساختار For … Each
ساختار For … Next
در این ساختار از یک متغیر استفاده میشه که مقدار آن در هر بار اجرا شدن کدهای درون حلقه For تغییر میکنه و زمانیکه به حد بالای مشخص شده برای این متغیر برسه از حلقه خارج میشه. به عنوان مثال در دستور زیر متغیر i از مقدار 1 شروع و تا 10 در هر بار چرخه تغییر میکنه (به عبارت دیگه دستور پاک کردن سلول ها 10 بار تکرار میشه)
1 2 3 |
For i = 1 to 10 Worksheets( "Sheet1" ).cells( i ,1 ).clear Next i |
در این کد مقدار i در شروع حلقه از یک شروع میشه و سلول A1 پاک میشه و زمانیکه به انتهای حلقه میرسه با توجه به اینکه هنوز مقدار i از 10 کمتر هست مجددا به ابتدای حلقه برمیگرده. اما در این حالت متغیر i مقدار دو خواهد داشت و سلول A2 پاک خواهد شد. این حلقه به همین صورت ادامه پیدا میکنه تا مقدار i به 10 برسد و سلول A10 پاک شود. در این زمان مقدار متغیر i به عدد 11 افزایش پیدا میکنه و با توجه به اینکه از عدد 10 بیشتر است از حلقه خارج میشه و دیگه سلول A11 پاک نمیشه.
بعد از آشنایی با ساختار حلقه For، این سوال پیش میاد که اگر بخوایم مقداری که در انتهای هر حلقه، مقداری که به متغیر شمارنده اضافه میشه چیزی به غیر از یک باشه چه باید کرد؟
فرض کنید قصد ایجاد داده های محور افقی یک نمودار هستید. این اعداد از 1 شروع و به فاصله 0.1 از هم زیاد میشه تا به 10 برسه. برای این کار از کد زیر استفاده میکنیم:
1 2 3 |
For i = 1 To10 Step 0.5 Worksheets( "sheet1" ).Cells( (i - 0.5) / 0.5, 1 ) = i Next i |
در این کد با استفاده از دستور Step تعیین کردیم که متغیر i در انتهای حلقه به مقدار 0.5 زیاد بشه. همچنین از این متغیر استفاده کردیم که در هر بار چرخش مقدار i با استفاده از دستور Cells در سلول های ستون A نوشته بشه.
برای اینکه چرخه از حالت افزایش (افزایش مقدار متغیر شمارنده) به حالت کاهشی تغییر کنه کافیه مقدار عددی که جلوی Step نوشته میشه عدد منفی باشه و مقدار اول و آخر باز جابجا بشه:
For i = 10 To 1 Step -1
نوع دیگری از حلقه ها در ماکرو که برای تعریف تکرار با شرط دلخواه وجود داره حلقه While هست که در مقاله ای دیگه بهش پرداخته میشه.
برچسب:متوسط
14 نظر
سلام بنده میخوام با استفاده از کد نویسی در اکسل تعدادی شیت ایجاد کنم . چطور میشه این کار را انجام داد ؟
آیا باید دستور ساخت شیت رو داحل یک حلق برد ؟
اگر درسته لطفا راهمایی کنید که چگونه این کار را انجام بدهم
درود بر شما
برای این کار ماکرو ضبط کنید و کد رو مشابه مقاله که ساختار for رو توضیح داده قرار بدید
با سلام
من 30 تا فایل به تعداد روز های ماه دارم که داخلش اطلاعات هست.
حالا می خوام یک فایل جمع درس کنم که بره از داخل فایل های دیگه چنتا سلول مشخص رو بخونه بیاره داخل مجموع.
چطور میتونم این کارو بکنم؟
البته این سی تا فایل به مرور تهیه میشوند و باید فایل جمع هر فایل جدید که به فولدر ماه اضافه میشه رو اتوماتیک پیدا کنه و چنتا سلول را بخونه بیاره داره خودش.
سپاس
درود بر شما
یا باید کدنویسی VBA انجام بدید یا با پاورکوئری انجام بدید
بسیار ممنون از پاسخ سریع تون
بله بنده اطلاع داشتم هردو روش فوق چاره کار است اما چه کنم که هیچ کدام را بلد نیستم و فیلم ها اموزشی نیز کمکی نکرد. شاید دوستی بتواند به بنده کمک کند؟!
سپاس از سایت بسیار پر بارتون
سوالتون چیزی نیست که بشه اینجا مشخصا جواب داد. بستگی به خیلی چیزها داره
اینجا فقط میشه راهنمایی کرد. مطابعه و یادگیری با خودتون
دستور merge رو در پاورکوئری مطالعه کنید و روی داده هاتون اعمال کنید
سلام مشکل این کد چیه؟
سلام
کد زیر رو با اکد انتهای پیام جابجا کنید:
کد صحیح:
من یک ستون دارم با یه سری داده های تکراری
در مقابل این ستون یه ستون دیگه هسات که شامل یه سری عدد هست
حالا میخوام بنویسم تا جایی که ستون اول با هم مساوی هستند دادهای ستون دوم رو کنار هم (جمع نکنه) بذاره
Sub ali()
Dim i As Integer
Dim j As Integer
j = i – 1
For i = 2 To 6
If Cells(i, “a”).Value = Cells(i – 1, “a”).Value Then
Cells(i – 1, “c”) = Cells(i – 1, “b”).Value & Cells(i, “b”).Value
End If
Next i
End Sub
این کد رو نوشتم اما این فقط دو ستون رو کنار هم میذاره
برا نوشتن حلقه تو این دستور کمک میخواستم ازتون
ممنون
سلام
برای حل این مسئله نیاز به تعریف حداقل دو حلقه تو در تو هست برای همین درون حلقه For اولی که خودتون نوشتید باید یک حلقه For دیگه تعریف کنید که بر اساس عددی که در ستون اول بررسی میکنید داده های ستون دوم (با استفاده از حلقه دوم) بررسی کنه و نتیجه دلخواه رو براتون ثبت کنه.
سلام برای تبدیل یک کد دستوری به یک حلقه چکاری باید انجام دهیم
مثلا کد
Private Sub TextBox1_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
If (KeyAscii > 47 And KeyAscii < 58) Then
KeyAscii = KeyAscii
Else
KeyAscii = 0
If Len(TextBox1.Text) < 10 Then
MsgBox "شما نمیتوانید حروف وارد کنید ، فقط باید عدد وارد کنید", vbMsgBoxRight, "اطلاعات ورودی اشتباه است"
Cancel = True
End If
End If
End Sub
را چطور حلقه کنم که بتونم برای چندین تکس باکس استفاده کنم
سلام، از حلقه ها برای انجام این کار استفاده کنید.
سلام
من این مقاله شما را خوندم . خیلی جالبه با vba خیل از حلقه های مورد نیاز را می تونم ایجاد کنم ولی مشکلی که دارم اینه که چطور وارد محیط vba بشم تا حلقه را ایجاد کنم. ممنون میشم اگه راهنمایی کنید.
درود بر شما
پست زیر رو مطالعه کنید:
https://excelpedia.net/macro-recording/