簡體   English   中英

(Excel VBA)使用while或for遍歷范圍?

[英](Excel VBA) loop through range with while or for?

最近,我被指出一些Excel函數是易失性的,這意味着每當工作表中有更改時就會觸發這些函數,而其他函數則不會。 現在,這使我想到大部分VBA使用情況都在一個范圍內循環,我想知道這兩種方法中的哪一種是首選,為什么? 情況下做while循環;

Dim i as long
i = 1
Do while cells(i,1) <> ""
    ...
    i = i + 1
Loop

或for循環

Dim curCell as cell
for curCell = cells(1,1) to cells(1,1).end(xlDown)
    ...
Next curCell

(請注意,確切的代碼可能不正確,因為我目前無法使用Excel訪問計算機)

編輯(在約翰的講話之后); 據我在第一個示例中看到的那樣,每次循環時都請求目標單元格值,在第二個示例中,僅兩次請求該單元格。end(xlDown)不需要vba層,但這是一個標准功能,因此第二個選項可能運行得更快。

提前致謝

Do..WhileFor EachFor i = x to y之間的時間沒有差異。 如果您想知道如何在每次循環時都不進行計算,則可以在循環之前使用Application.Calculation = xlCalculationManual之后使用Application.Calculation =xlCalculationAutomatic

當我說沒有區別時,幾乎沒有什么要注意的。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM