作者:金人瑞 《Excel VBA175例無理論純實戰教程》學員

最近正在學習鄭廣學老師的VBA 175例教程,這是一篇新手向的文章,也是一個新手的總結,高手可以批評文章中的不足之處,也可以無視,VBA中的IF判斷, 判斷一般起到控制作用,如鄭老師所說,就像一個水管中的控制閥,水來了,一個個的控制閥決定著流水的走向。而整個流程中判斷也的確有著控制流程走向的作用,可以說循環,判斷,數組是vba的三駕馬車,絕大部分的問題都是他們仨來解決的。其中for循環和if是新手最先學到的東西,今天我就來分享一下我這個新手在安裝"閥門"的時候遇到過的坑。
提到判斷,首先不得不提的就是IF函數,通常情況下IF有四中寫法
第一種, 開關型單句
如下圖:這是一個單句, 這是我自己取得名字,為了好理解,我們給他們取個外號"限定閥",在滿足某個條件時啟動執行某些語句.這樣寫的好處是加上備注以后一目了然,一看就知道有一個"閥門",不過這是我的個人習慣,在其他情況下,建議使用下面的方法.

第二種,開關型
這還是我自己取得名字,為了好理解,我們依舊給他們取個外號,"球閥",達到某條件就執行某個操作,就像水管里面的球閥,只有開關兩種情況,控制上也只能是執行和不執行的區別作用同第一種一樣,只不過多了一個end if ,可以將多個滿足則執行的語句包起來批量控制.

第三種,分流型
老規矩整個名字:分流控制閥,如下,可以看到if整句起到了控制流程走向的作用.

執行后如下:

第四種:多層控制型
如下圖,這種結構足夠完整,能控制不同條件的"水流"流向多個方向.在這里就不演示and和or了

為什么我會說他有坑呢?因為在一段程序中我們會時常遇到一個問題到底是用if包一個if,還是用if連接一個if以及判斷的位置問題.
先看個例子:


這是代碼和執行結果,在do/loop循環中,while i> 2 是判斷條件,判定符合條件則執行.下列語句,在上述代碼中I = I +1 執行以后I = 2 ,符合while >-=2,所以代碼可以得到右側結果,但是如果寫成下方這樣,則不執行,因為在I = i+1執行前就已經經過了while判斷,此時i=1,不符合.所以無結果

由上可以得到一個結論,判斷語句放置的地方一定要考究否則就會出bug,有些需要執行的語句就不執行.所以if作為常用判斷語句,其放置的地方一定是要符合邏輯下面總結一下我見過的兩種形式,更多復雜的樣式大家可自行拓展.這里只做模型.
(1) If /end if---if/end if 連接型
一般情況下,兩個判斷是獨立的時候才需要寫兩個if,

如上,我需要刪除考試沒寫名字的考生,也要選出語文為70分以上的考生標記為黃色,那么我就需要做兩個if語段,代碼如下

結果如下:

這個就是典型的兩個獨立的if在for循環中的應用,值得注意的是這兩個if在程序中是都會被執行的.但是下面這種情況就不一樣了,第一個if會被執行,但是第二個就不一定了,
(2) If –if/end if – end if ,第二種,if包含if
依舊是上面的例子,在找到語文為70分以上的學生以后,我希望在語文70分以上的顏色由黃色改為紅色,同時數學60分以上語文70分一下的底色改成黃色.代碼如下

執行結果如下

我們可以通過執行結果看到判斷數學大學60分這個判斷其實是被語文大于70分這個判斷"閹割"過的結果.這就是if包if 的模型.
總結一下:if連if,兩個判斷是獨立的.if包if兩個判斷不獨立,外層的if控制里層的if.第一種連接型的適用范圍是需要做兩個判斷,且所需要執行的代碼語句不一樣,比如刪除和上色.不同的判定條件有不同的語句執行.第二種包裹型if,適用范圍是兩層判斷,先篩選出來的數據要再次篩選,如果判定成功需要執行的語句一樣,比如都是底色上紅色,那么些一個and連接語句同時滿足即可,但是執行想語句不一樣,則需要寫成包裹型.
補充一點:學vba時間不長,所幸認識鄭老師不算太晚,見過的大神多,他們的特點就是理解能力強,思路清晰,作為新手我覺得注釋很重要,一來寫代碼的設計思路,二來寫語句的作用,這些都至關重要,再一個就是建立自己的理解模型就像上面的if,代碼的設計其實是有模型思維的,任何事物借助模型都可以快速的去理解,通過修改模型,引用模塊,即使很復雜的代碼我們也能很快的完成。
最后給大家看看鄭老師的無敵IF多層程序框圖

.最后說一點學習歷程
一開始也是找各種免費課,速成課,看完速成課的最大結果其實是他給的案例你會,你自己的案例不會,還不容易百度到了吧,黃花菜都老了,這不是VBA應該有的效率,我要的是高效率,不僅快捷還要方便。于是我在QQ閱讀買了書,又買了紙質書!加了群,可還是那樣,書里面只帶你入門,他寫的很多我都會,不會的也看不懂,場面一度極其尷尬。究竟什么是提高?究竟如何才能提高?這兩個問題直到我在b站看到了鄭老師我才反應過來,真正的高手是能在一瞬間就有思路怎樣去處理數據,也能在很短的時間里面調用寫好的模塊。這才是真正的高效率。這也恰恰是這么長時間我在其他課程里面沒聽到的東西,雖然前面走了很多彎路,不過這一個月來我每天上廁所都要看老師的視頻,VBA水平突飛猛進,學習上癮的這種感覺,比打游戲上癮還強烈!!!