vba - 如何使用行号自动填充 VBA 编辑器?

标签 vba basic

出于调试原因,我想在我的 VBA 代码中包含行号。这将使我知道发生特定错误的位置。

是否有自动功能(例如设置中的选项)?还是我需要编写自己的宏?

如果我需要编写自己的宏来完成这项任务,我将如何去做这样的事情?

最佳答案

你不想要行号。
不是出于“调试原因”,也不是出于任何原因。不推荐使用行号是有原因的:它们是在程序存在之前的古代遗迹,GOTO到达任何地方的唯一途径。Erl仅返回引发错误之前最后遇到的行号。如果您正在记录错误,这可能意味着误导性错误日志:

Sub DoSomething()
10 On Error GoTo 50
   Debug.Print 42 / 0
30 Exit Sub

50 Debug.Print "Error raised on line " & Erl 'returns 10
End Sub
此外,行号只有 Integer分辨率(一个 VBA 模块最多可以有 65,535 行,是分辨率的两倍),如果你不记住这一点,它将默默地失败并愉快地报告错误的行号:
Sub DoSomething()
99997 On Error GoTo 99999
99998 Debug.Print 42 / 0
99999
      Debug.Print Erl   'Prints 34462 - and which line is that?
End Sub
任何严肃的 VBA 应用程序都将使用 结构化错误处理 反而。
编写小的、专门的程序(即编写遵循现代最佳实践的代码),行号变得毫无意义。
维护行号是一件令人头疼的事情;它们使代码困惑,使其整体更难阅读(因此更难调试)。

也就是说,IIRC MZ-Tools 3 具有这样的功能。
请记住,当行号是一个东西时,BASIC 看起来像这样:
10 GOSUB 100
20 GOSUB 1000
99 END
100 REM CLEAR SCREEN
110 PRINT CHR$(147)
120 RETURN
200 REM MODULO
210 LET MOD% = V%-INT(V%/FB%)*FB%
220 RETURN
1000 REM INIT VARIABLES
1010 LET FIZZ$ = "FIZZ"
1011 LET BUZZ$ = "BUZZ"
1020 LET FIZZ% = 3
1021 LET BUZZ% = 5
1030 LET MIN% = 1
1031 LET MAX% = 15
1100 PRINT FIZZ$ + ":" + STR$(FIZZ%)
1101 PRINT BUZZ$ + ":" + STR(BUZZ%)
1102 PRINT FIZZ$ + BUZZ$ + ":" + STR$(FIZZ%*BUZZ%)
1105 PRINT
2000 REM ACTUAL FIZZBUZZ LOOP
2010 FOR X = MIN% TO MAX%
2015 LET RESULT$ = STR$(X)
2020 LET FB% = FIZZ%*BUZZ%
2021 LET V% = X
2024 GOSUB 200
2025 IF MOD%=0 THEN LET RESULT$=FIZZ$+BUZZ$ : GOTO 2050
2030 LET FB% = FIZZ%
2031 GOSUB 200
2035 IF MOD%=0 THEN LET RESULT$=FIZZ$ : GOTO 2050
2040 LET FB% = BUZZ%
2041 GOSUB 200
2045 IF MOD%=0 THEN LET RESULT$=BUZZ$ : GOTO 2050
2050 PRINT RESULT$
2090 NEXT X
2099 RETURN
以上是工作 Commodore 64 BASIC 2.0 程序。 VBA 具有极好的向后兼容性。只需稍作修改,它就可以在 VBA 中运行:
Sub Main()
10     GoSub 100
20     GoSub 1000
99     End
100     Rem CLEAR SCREEN
110     'Debug.Print Chr$(147) 'Chr$(147) was a special character on C64
120     Return
200     Rem MODULO
210     Let Modulo% = V% - Int(V% / FB%) * FB%
220     Return
1000     Rem INIT VARIABLES
1010     Let FIZZ$ = "FIZZ"
1011     Let BUZZ$ = "BUZZ"
1020     Let FZZ% = 3
1021     Let BZZ% = 5
1030     Let Min% = 1
1031     Let Max% = 15
1100     Debug.Print FIZZ$ + ":" + Str$(FZZ%)
1101     Debug.Print BUZZ$ + ":" + Str(BZZ%)
1102     Debug.Print FIZZ$ + BUZZ$ + ":" + Str$(FZZ% * BZZ%)
1105     Debug.Print
2000     Rem ACTUAL FIZZBUZZ LOOP
2010     For X = Min% To Max%
2015     Let RESULT$ = Str$(X)
2020     Let FB% = FZZ% * BZZ%
2021     Let V% = X
2024     GoSub 200
2025     If Modulo% = 0 Then Let RESULT$ = FIZZ$ + BUZZ$: GoTo 2050
2030     Let FB% = FZZ%
2031     GoSub 200
2035     If Modulo% = 0 Then Let RESULT$ = FIZZ$: GoTo 2050
2040     Let FB% = BZZ%
2041     GoSub 200
2045     If Modulo% = 0 Then Let RESULT$ = BUZZ$: GoTo 2050
2050     Debug.Print RESULT$
2090     Next X
2099     Return
End Sub
不要编写 1980 年的代码,我们已经过了 40 年。
Commodore-64 BASIC 2.0 FIZZBUZZ

关于vba - 如何使用行号自动填充 VBA 编辑器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35459541/

相关文章:

vba - 使用vba访问outlook中的另一个邮箱

mysql - 如何在 Visual Basic 中显示 MySQL 输出?

vba - Range.Find.执行错误 "Argument Not Optional"Excel VBA

excel - 将嵌入的 Word 文档另存为 PDF

syntax-error - 语法错误,基本中缺少符号

basic - BASIC GOTO 和 GOSUB 语句有什么区别

algorithm - 如何通过 PICAXE 14M2 控制占空比来保持直流电机速度(闭环反馈)

excel - 字母 f 在 VBA 中被视为制表符

excel - 错误 : Invalid Use of Property when attemting to reset Excel UsedRange