جلسه هفتم- ساختار شرطی Select Case

 

 Sub level( )

 x = Range("a1").Value

 Select Case x

 Case 17 To 20

Range("b1").Value = " A"

 Case 14 To 17

Range("b1").Value = " B"

            Case 12 To 14

Range("b1").Value = " C"

 Case 10 To 12

Range("b1").Value = " D"

            Case 0 To 10

Range("b1").Value = " E"

Case Else

Range("b1").Value = "false"

 End Select 

End Sub

 

ساختار حلقه ای FOREach - NEXT

حلقه ها دستوراتی هستند که می توان جهت انجام دستورات تکراری از آنها استفاده نمود. حلقه FOREach برای کار بر روی عضوهای(members) یک مجموعه(collection) استفاده می شود. مجموعه شامل تعدادی شیء یکسان است. به عنوان مثال Range("A1:A10") یک ‍collection ‌ است زیرا تعدادی عضو به نام سلول است که همگی از یک جنس هستند. worksheet های یک فایل اکسل مجموعه ای به نام Worksheets تشکیل می دهند. چارتهای یک فایل اکسل مجموعه ای به نام Charts تشکیل می دهند.

الگوی زیر الگوی استفاده از یک حلقه FOREach در برنامه نویسی می باشد:

 

 

For Each عضو In مجموعه

            دستورات

NEXT

 

 

 

در برنامه ای که در زیر نوشته شده عملیات مورد نظر بر روی ردیفهای 1 تا 10 ستون A  انجام می شود.برنامه به گونه ای نوشته شده است که اعداد کمتر از 10موجود در ستون اول، را Bold ‌کند

 

 

حال با استفاده و ترکیب دو دستور FOR-NEXTبه سادگی برنامه مورد اشاره به شرح ذیل نوشته می شود:

 

 Sub range_leve()

For Each c In Range("a11:h20")

    If x < 10 Then c.Font.Bold = True

 Next

 

End Sub

استفاده از دستور ROW در برنامه:

 

برنامه بالا برنامه مناسبی بود اما در فاز بعدی برنامه نویسی ما خواهان این نکته هستیم برنامه ای نوشته شود  که به ازای مقادیر مختلف در یک ستون در اکسل عباراتی متناسب با آن اعداد را در مقابل آنها بنویسد.

تنها نکته موجود در این برنامه وجود دستور ROW است که از دسته دستوراتی مانند VALUE می باشد که در اینجا ROW به مفهوم ردیف مورد نظر می باشد.و برای نیل به هدف بالا می بایست دو متغیر تعریف نمود.

متغیر اول برای عدد مورد نظر که هدف برنامه آن است و متغیر دوم ردیف عدد مود نظر که برای اینکه در مقابل آن عدد باید عبارت مورد نظر برنامه تایپ گردد، مورد نیاز است.مع الوصف برنامه مورد نظر به شکل زیر نوشته می شود:

 

 

Sub range_level()

 Dim c As Range

 For Each c In Range("a1:a10")

 x = c.Value

i = c.Row

 

Select Case x

 

Case 17 To 20

                   Cells(i, 2) = "A"

 Case 14 To 17

                  Cells(i, 2) = "B"

 Case 12 To 14

                    Cells(i, 2) = "C"

Case 10 To 12

                    Cells(i, 2) = "D"

 Case 0 To 10

                 Cells(i, 2) = "E"

 Case Else

                      Cells(i, 2) = "ERROR"

End Select

 

 Next

 

End Sub

/ 3 نظر / 331 بازدید
یاسر

سلام بسیار سپاسگذارم عالی بود من که لذت بردم از این مطالب دست شما درد نکنه

م.رضایی

سلام ممنون از سایت خوبتون من واقعا از تمام اطلاعات شما استفاده کردم .ولی یک مشکل در استفاده از این vb دارم ان هم این است که چگونه می توانم یک محدود خاص و متفاوت برای یک بخش یا سطر تعریف کنم.

مصطفی

من یه مهندس برق هستم با زبان های برنامه نویسی "C" و برنامه نویسی متلب هم آشنایی دارم و الان نیاز به یادگیری برنامه نویسی در اکسل داشتم...شروع کردم به خوندن مطالب وبلاگ شما...جلسه 1 تا 7 رو خوندم و تمرین کردم... بسیار ساده و روان توضیح داده بودید...بسیار ممنون از این کار شما...خیلی عالی بود... اگر زمانی کمکی از جهات دیگه از دستم برمیومد بفرمایید حتما در خدمتم