shell if多個條件判斷_萌新關于Excel VBA中IF條件判斷語句的一點心得體會

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

3587134e412dccb02089665973392e12.png

最近正在學習鄭廣學老師的VBA 175例教程,這是一篇新手向的文章,也是一個新手的總結,高手可以批評文章中的不足之處,也可以無視,VBA中的IF判斷, 判斷一般起到控制作用,如鄭老師所說,就像一個水管中的控制閥,水來了,一個個的控制閥決定著流水的走向。而整個流程中判斷也的確有著控制流程走向的作用,可以說循環,判斷,數組是vba的三駕馬車,絕大部分的問題都是他們仨來解決的。其中for循環和if是新手最先學到的東西,今天我就來分享一下我這個新手在安裝"閥門"的時候遇到過的坑。

提到判斷,首先不得不提的就是IF函數,通常情況下IF有四中寫法

第一種, 開關型單句

如下圖:這是一個單句, 這是我自己取得名字,為了好理解,我們給他們取個外號"限定閥",在滿足某個條件時啟動執行某些語句.這樣寫的好處是加上備注以后一目了然,一看就知道有一個"閥門",不過這是我的個人習慣,在其他情況下,建議使用下面的方法.

4b753a5a839273f07ed27617609769ed.png

第二種,開關型

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

f52d0bca7782efdfb644fb4a3c44bb6d.png

第三種,分流型

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

c9dda21f7bb7b8792582c626e8e2ad8e.png

執行后如下:

58115dafe242d82d4bfc173c63d21ce6.png

第四種:多層控制型

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

8fe5cdcdf829215bd74ca0f0a7a5903d.png

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

先看個例子:

c03bd0413785bf8f92c82f5ca07b9fca.png
7acdef12026dad14fc2e67ca1eacae55.png

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

5184414272125cfef6825c1e1b7ad64f.png

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

(1) If /end if---if/end if 連接型

一般情況下,兩個判斷是獨立的時候才需要寫兩個if,

b5f1afa4a00f8973ba4a3ca8e177b70a.png

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

a8fa1f55e29f16551e50b4339e6cbca6.png

結果如下:

e6387e9824bbe3a8810b4c73f21551cb.png

這個就是典型的兩個獨立的if在for循環中的應用,值得注意的是這兩個if在程序中是都會被執行的.但是下面這種情況就不一樣了,第一個if會被執行,但是第二個就不一定了,

(2) If –if/end if – end if ,第二種,if包含if

依舊是上面的例子,在找到語文為70分以上的學生以后,我希望在語文70分以上的顏色由黃色改為紅色,同時數學60分以上語文70分一下的底色改成黃色.代碼如下

f7e426b82be0c088c672903d8ebe7c06.png

執行結果如下

cbe2931605b9e78bc513022673e1488c.png

我們可以通過執行結果看到判斷數學大學60分這個判斷其實是被語文大于70分這個判斷"閹割"過的結果.這就是if包if 的模型.

總結一下:if連if,兩個判斷是獨立的.if包if兩個判斷不獨立,外層的if控制里層的if.第一種連接型的適用范圍是需要做兩個判斷,且所需要執行的代碼語句不一樣,比如刪除和上色.不同的判定條件有不同的語句執行.第二種包裹型if,適用范圍是兩層判斷,先篩選出來的數據要再次篩選,如果判定成功需要執行的語句一樣,比如都是底色上紅色,那么些一個and連接語句同時滿足即可,但是執行想語句不一樣,則需要寫成包裹型.

補充一點:學vba時間不長,所幸認識鄭老師不算太晚,見過的大神多,他們的特點就是理解能力強,思路清晰,作為新手我覺得注釋很重要,一來寫代碼的設計思路,二來寫語句的作用,這些都至關重要,再一個就是建立自己的理解模型就像上面的if,代碼的設計其實是有模型思維的,任何事物借助模型都可以快速的去理解,通過修改模型,引用模塊,即使很復雜的代碼我們也能很快的完成。

最后給大家看看鄭老師的無敵IF多層程序框圖

643e7b7388f9b8c166969b99da12c96b.png

.最后說一點學習歷程

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

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/455311.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/455311.shtml
英文地址,請注明出處:http://en.pswp.cn/news/455311.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Django筆記01-基礎:一個完美主義的web框架

淺談Web框架 一,什么是框架? 軟件框架就是為實現或完成某種軟件開發時,提供了一些基礎的軟件產品, 框架的功能類似于基礎設施,提供并實現最為基礎的軟件架構和體系 通常情況下我們依據框架來實現更為復雜的業務程序開發 一個字,框架就是程序的骨架 二,框架的優缺點 可重…

mysql存儲引擎的一點學習心得總結

首先我們應該了解mysql中的一個重要特性——插件式存儲引擎,從名字就能夠看出在mysql中,用戶能夠依據自己的需求隨意的選擇存儲引擎。實際上也是這樣。即使在同一個數據庫中。不同的表也能夠使用不同的存儲引擎。Mysql中支持的存儲引擎有非常多種&#x…

常見音視頻格式(轉載)

Contents 1 MPEG 系列 1.1 MPEG-1 1.2 MPEG-2 1.3 MPEG-4 1.4 MPEG-4 AVC 1.5 MPEG Audio Layer 1/2 1.6 MPEG Audio Layer 3 1.7 MPEG-2 AAC 1.8 MPEG-4 AAC 1.9 MPEG-4 aacPlus 1.10 MPEG-4 VQF 1.11 mp3PRO 1.12 MP3 Surround 2 DVD系列 2.1 Dolby Digital AC3 2.2 Dolby D…

編程語言難度排名_谷歌排名第一的編程語言,小學生拿來做答題,分分鐘鐘搞定高難度算法!...

點擊上方藍色文字關注我們吧谷歌排名第一的編程語言時什么?毫無疑問:肯定是 Python。 也難怪,作為大數據時代和人工智能時代的必備語言,Python 的優點太多了,語言簡潔、易學、開發效率高、可移植性強...... 另外&#…

poj 2484 A Funny Game

題目:http://poj.org/problem?id2484 一,題意: n個硬幣圍成一個圈,Alice與Bob輪流從圈中取硬幣。每次能夠取一枚或者連續的兩枚。 硬幣取走后留下的空位不用填補,空位相隔的兩個硬幣視為不相鄰。Alice第一個開始取。 …

58到家MySQL軍規升級版

一、基礎規范 表存儲引擎必須使用InnoDB 表字符集默認使用utf8,必要時候使用utf8mb4 解讀: (1)通用,無亂碼風險,漢字3字節,英文1字節 (2)utf8mb4是utf8的超集&#…

jsp 中包含 一個路徑為變量的文件

<head><base href"<%basePath%>"><% String fileroot"MyJsp.jsp"; %> </head><body><jsp:include page"<%fileroot %>" ></jsp:include></body>

FFMPEG中H.264的算法文檔--整理自ffmpeg論壇等

xchg_mb_border() 交換 MB 邊界的像素。閱讀代碼可知&#xff0c;交換雙方為邊界緩存 (left_border,top_borders) 與重建圖象中的相應數據。其中 xchg 參數是否為 1 決定&#xff0c;在從邊界緩存賦值到重建圖象的同時&#xff0c;是否保存重建圖象的數據到邊界緩存。 此函數僅…

python局部靜態變量_全局變量、局部變量和靜態變量

全局變量和局部變量在寫代碼時需要區分清楚&#xff0c;不然會出大問題。不同語言定義不同范圍的變量的寫法有很大的區別。那么靜態變量是在什么場景下用到呢&#xff1f;我們來假設這樣一個場景&#xff1a;在函數內部定義的變量&#xff0c;當程序執行到它的定義處時&#xf…

【轉載】fullpage.js學習

參考網址&#xff1a;http://www.dowebok.com/77.html 上面有詳細介紹及案例展示&#xff0c;很不錯哦&#xff0c;可以先去看看demo 一、簡介 fullPage.js 是一個基于jQuery的插件&#xff0c;它能夠很方便、很輕松的制作出全屏網站&#xff0c;主要功能有&#xff1a; 1.支持…

Deepin 下安裝 LAMP

ubuntu/deepin linux 下使用 apt-get 安裝所需套的軟件 LAMP 1. 安裝 apacache2 apt-get install apache2 配置文件&#xff1a;/etc/apache2/apache2.conf service apache2 start service apache2 stop service apache2 restart 2. 安裝 mysql sudo apt-get install my…

webpack打包測試_webpack入門筆記(一)

webpack 是一個現代 JavaScript 應用程序的靜態模塊打包器(module bundler)。當 webpack 處理應用程序時&#xff0c;它會遞歸地構建一個依賴關系圖(dependency graph)&#xff0c;其中包含應用程序需要的每個模塊&#xff0c;然后將所有這些模塊打包成一個或多個 bundle。webp…

[js高手之路] 跟GhostWu一起封裝一個字符串工具庫-擴展字符串位置方法(4)

本文&#xff0c;我們接著之前的框架繼續擴展&#xff0c;這次擴展了一共有5個與字符串位置相關的方法 between( left, right ) 返回兩個字符串之間的內容&#xff0c; 如果第二個參數沒有傳遞&#xff0c;返回的是找到的第一個參數 之后 到 字符串結尾的所有字符串 如果第二個…

ffmpeg和SDL學習筆記

根據ffmpeg官方網站上的例子程序開始學習ffmpeg和SDL編程。 SDL是一個跨平臺的多媒體開發包。適用于游戲&#xff0c;模擬器&#xff0c;播放器等應用軟件開發。支持linux 、win32 等操作系統。 主要應用&#xff1a; 視頻 設置8bpp或更高的任意色彩深度的視頻模式。如果某個…

百練-16年9月推免-B題-字符串判等

2743:字符串判等 查看提交統計提示提問總時間限制: 1000ms內存限制: 65536kB描述判斷兩個由大小寫字母和空格組成的字符串在忽略大小寫&#xff0c;且忽略空格后是否相等。 輸入兩行&#xff0c;每行包含一個字符串。輸出若兩個字符串相等&#xff0c;輸出YES&#xff0c;否則輸…

mysql中的內置函數

mysql內置函數列表可以從mysql官方文檔查詢&#xff0c;這里僅分類簡單介紹一些可能會用到的函數。 1 數學函數 abs(x) pi() mod(x,y) sqrt(x) ceil(x)或者ceiling(x) rand(),rand(N):返回0-1間的浮點數&#xff0c;使用不同的seed N可以獲得不同的隨機數 round(x, D)&#xff…

待整理

CNN 適合處理圖片類輸入數據&#xff0c;單獨的&#xff0c;數據之間沒有關系。 rnn則適合處理序列類數據&#xff0c;視頻幀&#xff0c;語言。 深度神經網絡一般指隱藏層大于2的神經網絡。深層網絡相對于淺層網絡&#xff0c;表達能力更強。僅有一個隱藏層的神經網絡就能擬合…

希爾伯特變換_學習筆記1-傅里葉變換1

最終目標是解微分方程。第一章首先介紹了一般意義下的傅里葉變換&#xff0c;之后逐漸將傅里葉變換的概念抽象化&#xff0c;將變換的定義域進行拓展。最后少量介紹傅里葉變換在偏微分方程中的應用。習題解答是自己寫的&#xff0c;有的不會&#xff0c;有的不知道對不對。傅里…

使用 sitemesh/decorator裝飾器裝飾jsp頁面(原理及詳細配置)

摘要&#xff1a;首先這個Decorator解釋一下這個單詞&#xff1a;“裝飾器”&#xff0c;我覺得其實可以這樣理解&#xff0c;他就像我們用到的Frame&#xff0c;他把每個頁面共有的東西提煉了出來&#xff0c;也可能我們也會用各種各樣的include標簽&#xff0c;將我們的常用頁…

FFPLAY的原理(一)

概要電影文件有很多基本的組成部分。首先&#xff0c;文件本身被稱為容器Container&#xff0c;容器的類型決定了信息被存放在文件中的位置。AVI和Quicktime就是容器的例子。接著&#xff0c;你有一組流&#xff0c;例如&#xff0c;你經常有的是一個音頻流和一個視頻流。&…