2022年7月25日 星期一

vba 偵錯入門

vba 偵錯,偵錯可說是每一個寫code人必經之路,簡單分想一下,小編自己偵錯常用的方法。

example1:

a = 1

b = 0

c = a / b

執行example1code後,會出現以下錯誤提醒畫面(熟悉嗎?)

圖1.錯誤
點選確定後,就自動結束執行運作了,今天還好僅有3行,如果300行 或3000行,那.......還真的不知道是那一行錯了 xd

所以這時候要加上一行,本篇主角 "on error goto line1"的指令;example2 參如下。

example2:

on error goto line1

a = 1

b = 0

c = a / b

line1:

MsgBox Err.Description & ";" & Err.Number '這行筆者加的,讓錯誤變成對話框內容

DEBUG.PRINT Err.Description & ";" & Err.Number   '這行筆者加的,讓錯誤顯示在即時運算畫面當中。

圖2.

圖3.

接下來,要如何偵錯錯誤行別??

使用RESUME;參example3 如下。


example3:

on error goto line1

a = 1

b = 0

c = a / b

line1:

MsgBox Err.Description & ";" & Err.Number '這行筆者加的,讓錯誤變成對話框內容

DEBUG.PRINT Err.Description & ";" & Err.Number   '這行筆者加的,讓錯誤顯示在即時運算畫面當中。

RESUME ' '這行筆者加的的目的,是要顯示錯誤行別 記得要點反紅點

圖4.

再透過F8功能鍵逐一執行,就可以知道那一行掛了

圖5.F8逐行執行動畫
(動畫:美執行一行等於按一次F8)






沒有留言:

張貼留言

指數變化(2025.08.29) 開始透過AI做整理

 指數變化(2025.08.29) 開始透過AI做整理 上周焦點: 8/19(二)   美國房屋開工率 5%月增  美國建築許可月增率 月增2.8% 8/20(三)   美國房貸綜合指數 月減0.5%  美國30年期房貸利率 6.69%  美國15年期房貸利率 5.8~5.71%...