Anweisung Input#
Erlaubt das Einlesen von Daten aus einer geöffneten sequentiellen Datei.
Syntax:
Input #Dateinummer As Integer; Var1[, Var2[, Var3[, ...]]]
Parameter:
Dateinummer: Die Nummer der Datei mit den zu lesenden Daten. Die Datei muss zuvor mit einer Anweisung Open und dem Schlüsselwort INPUT geöffnet worden sein.
Var: Eine numerische oder Zeichenkettenvariable, der Sie die aus der geöffneten Datei gelesenen Werte zuweisen.
Die Anweisung Input# liest numerische Werte oder Zeichenketten aus einer geöffneten Datei und weist die Daten einer oder mehreren Variablen zu. Numerische Variablen werden bis zum ersten Wagenrücklauf (Asc=13), Zeilenvorschub (Asc=10), Leerzeichen oder Komma gelesen. Zeichenkettenvariablen werden bis zum ersten Wagenrücklauf (Asc=13), Zeilenvorschub (Asc=10) oder Komma gelesen.
Daten und Datentypen in der geöffneten Datei müssen in derselben Reihenfolge wie die im Parameter "Var" übergebenen Variablen erscheinen. Wenn Sie versuchen, einer numerischen Variable nicht-numerische Werte zuzuweisen, erhält "Var" den Wert "0".
Durch Kommata getrennte Datensätze können einer String-Variablen nicht zugewiesen werden. Anführungszeichen (") in der Datei werden ebenfalls ignoriert. Um diese Zeichen aus der Datei einzulesen, verwenden Sie die Anweisung Line Input#, um reine Textdateien (Dateien, die ausschließlich druckbare Zeichen enthalten) zeilenweise einzulesen.
Wird während des Lesens eines Datenelements das Ende der Datei erreicht, so wird der Lesevorgang abgebrochen, und es tritt ein Fehler auf.
Beispiel:
Sub ExampleWorkWithAFile
Dim iCount As Integer
Dim sName As String
Dim sValue As Integer
Dim sFileName As String
sFileName = "c:\data.txt"
iCount = Freefile
' Schreibe Daten ( welche wir später mit Input lesen werden ) in Datei
Open sFileName For Output As iCount
sName = "Hamburg"
sValue = 200
Write #iCount, sName, sValue
sName = "New York"
sValue = 300
Write #iCount, sName, sValue
sName = "Miami"
sValue = 459
Write #iCount, sName, sValue
Close #iCount
iCount = Freefile
' Lese Datendatei mittels Input
Open sFileName For Input As iCount
Input #iCount; sName, sValue
MsgBox sName & " " & sValue
Input #iCount; sName, sValue
MsgBox sName & " " & sValue
Input #iCount; sName, sValue
MsgBox sName & " " & sValue
Close #iCount
End Sub