在您的代码中,第二个FIELD
声明会覆盖第一个FIELD
声明。在 BASIC 中,声明中FIELD
声明的变量应该是不同的。
如果你使用下面的代码,你会看到一个有趣的结果:
文件 testfile.000 将包含 1212(仅第一个LSET
设置文件 #1 的字段 x$)
文件 testfile.001 将包含 1488(两者都LSET
设置了文件 #2 的字段 x$)。
file1$ = "testfile.000"
file2$ = "testfile.001"
OPEN file1$ FOR RANDOM AS #1 LEN = 2
FIELD #1, 2 AS x$
LSET x$ = "12"
OPEN file2$ FOR RANDOM AS #2 LEN = 2
FIELD #2, 2 AS x$
LSET x$ = "14"
PUT #1, 1: REM This puts 12 into the 1st file#1 record.
PUT #2, 1
LSET x$ = "88"
PUT #1, 2: REM this puts 12 into the 2nd file#1 record
PUT #2, 2
CLOSE #1
CLOSE #2
END
在 QB 中,您可以使用二进制文件,如下面的代码所示。此模式允许您在多个文件上写入相同的变量。
当您使用这种文件时,您将可以完全控制文件中数据的维度和位置。
file1$ = "testfile.000"
file2$ = "testfile.001"
OPEN file1$ FOR BINARY AS #1
OPEN file2$ FOR BINARY AS #2
x$ = "29"
PUT #1, 1, x$
PUT #2, 1, x$
CLOSE #1
CLOSE #2
END