The [[INPUT #]] file or port statement reads sequential data using one variable or a comma separated list of matching variable types. {{PageSyntax}} : [[INPUT #]]{{Parameter|fileNumber&}}, {{Parameter|variable1}}[, {{Parameter|variable2}}, ..., {{Parameter|variableN}}] {{Parameters}} * {{Parameter|fileNumber&}} is a positive [[LONG]] integer value used to [[OPEN]] the file FOR [[INPUT (file mode)|INPUT]] mode. * The [[type]] of the ''variable'' used defines the value or list of values to be returned from the file. Numeric types must match the values returned. * As reflected in the syntax you can list a number of variables with different types seperated by a comma and they will hold the values in the file (keep in mind that the information in the file should match the variable types used). {{PageDescription}} * The file number can be determined by the programmer or be an unused number returned by the [[FREEFILE]] function. * Variable types must match the numerical [[type]]s being read. [[STRING]] variables can return unquoted numeric values. * Leading or trailing spaces of [[STRING]] values must be inside of quotes. [[WRITE (file statement)|WRITE #]] writes strings inside of quotes automatically. [[PRINT (file statement)|PRINT #]] removes quotes. * [[INPUT #]] will read each value until it encounters a comma for the next value in a list. * Use the [[EOF]] function to avoid reading past the end of a file. * Files created by [[WRITE (file statement)|WRITE #]] usually have the same number of values on each file line. If INPUT reads more or less values, it may read beyond the [[EOF|end of file]] or return bad data. * Use the [[LINE INPUT (file statement)]] for files created with PRINT # or PRINT #, USING. * '''INPUT can read Excel CSV files, but beware of unquoted text or numerical values containing commas.''' {{PageExamples}} ''Example 1:'' Writes new data to a text file sequentially and reads it back to the program screen. {{CodeStart}} '' '' filename$ = "testfile.dat" x = 1: y = 2: z$ = "Three" {{Cl|OPEN}} filename$ {{Cl|FOR...NEXT|FOR}} {{Cl|OUTPUT}} {{Cl|AS}} #1 'opens and clears an existing file or creates new empty file {{Cl|WRITE (file statement)|WRITE}} #1, x, y, z$ {{Cl|CLOSE}} #1 {{Cl|PRINT}} "File created with data. Press a key!" K$ = {{Cl|INPUT$}}(1) 'press a key {{Cl|OPEN}} filename$ {{Cl|FOR (file statement)|FOR}} {{Cl|INPUT (file mode)|INPUT}} {{Cl|AS}} #2 'opens a file to read it {{Cl|INPUT (file statement)|INPUT}} #2, a, b, c$ {{Cl|CLOSE}} #2 {{Cl|PRINT}} a, b, c$ {{Cl|WRITE}} a, b, c$ {{Cl|END}} '' '' {{CodeEnd}} {{OutputStart}} 1 2 Three 1,2,"Three" {{OutputEnd}} : ''Screen output:'' [[PRINT]] string values will not display enclosing quotes. [[WRITE]] screen displays will. {{TextStart}}1,2,"Three" '' '' {{TextEnd}} : ''File content:'' [[WRITE (file statement)|WRITE]] string values will include quotation marks, but they are not required to read the file value as a string. ''Example 2:'' Commas inside of string values will not affect the INPUT value as those commas are not [[WRITE (file statement)|WRITE]] separators. {{CodeStart}} '' '' x$ = "Hello, how are you?" y$ = "I'm fine." {{Cl|OPEN}} "testinp.dat" {{Cl|FOR...NEXT|FOR}} {{Cl|OUTPUT}} {{Cl|AS}} #1 {{Cl|WRITE (file statement)|WRITE}} #1, x$, y$ {{Cl|CLOSE}} #1 {{Cl|OPEN}} "testinp.dat" {{Cl|FOR (file statement)|FOR}} {{Cl|INPUT (file mode)|INPUT}} {{Cl|AS}} #1 {{Cl|INPUT (file statement)|INPUT}} #1, a$, b$ {{Cl|CLOSE}} #1 {{Cl|PRINT}} a$, b$ {{Cl|WRITE}} a$, b$ '' '' {{CodeEnd}} {{OutputStart}}Hello, how are you? I'm fine. "Hello, how are you?","I'm fine."{{OutputEnd}} {{TextStart}}"Hello, how are you?","I'm fine."{{TextEnd}} : ''File content:'' Commas inside of strings delimited with quotes will be ignored. [[WRITE (file statement)|WRITE]] will always enclose string values in quotes. {{PageSeeAlso}} * [[INPUT (file mode)]], [[LINE INPUT (file statement)|LINE INPUT #]], [[INPUT$]] {{text|(file input)}} * [[INPUT]], [[LINE INPUT]], [[INPUT$]] {{text|(keyboard input)}} * [[PRINT (file statement)|PRINT #]], [[PRINT USING (file statement)|PRINT #, USING]] * [[GET|GET #]] {{PageNavigation}} <