gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 21:36:26 26 4
gpt4 key购买 nike

出于调试原因,我想在我的 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com