The Python interpreter can get its input from a number of sources: from a scriptpassed to it as standard input or as program argument, typed in interactively,from a module source file, etc. This chapter gives the syntax used in thesecases.
While a language specification need not prescribe how the language interpreteris invoked, it is useful to have a notion of a complete Python program. Acomplete Python program is executed in a minimally initialized environment: allbuilt-in and standard modules are available, but none have been initialized,except forsys (various system services),builtins (built-infunctions, exceptions andNone) and__main__. The latter is used toprovide the local and global namespace for execution of the complete program.
The syntax for a complete Python program is that for file input, described inthe next section.
The interpreter may also be invoked in interactive mode; in this case, it doesnot read and execute a complete program but reads and executes one statement(possibly compound) at a time. The initial environment is identical to that ofa complete program; each statement is executed in the namespace of__main__.
Under Unix, a complete program can be passed to the interpreter in three forms:with the-cstring command line option, as a file passed as thefirst command line argument, or as standard input. If the file or standardinput is a tty device, the interpreter enters interactive mode; otherwise, itexecutes the file as a complete program.
All input read from non-interactive files has the same form:
file_input ::= (NEWLINE |statement)*
This syntax is used in the following situations:
Input in interactive mode is parsed using the following grammar:
interactive_input ::= [stmt_list] NEWLINE |compound_stmt NEWLINE
Note that a (top-level) compound statement must be followed by a blank line ininteractive mode; this is needed to help the parser detect the end of the input.
There are two forms of expression input. Both ignore leading whitespace. Thestring argument toeval() must have the following form:
eval_input ::=expression_list NEWLINE*
Note: to read ‘raw’ input line without interpretation, you can use thereadline() method of file objects, includingsys.stdin.
10. Full Grammar specification
Enter search terms or a module, class or function name.