9. 顶层组件

Python 解释器可以从多个来源获取输入:从作为标准输入或程序参数传递给它的脚本、交互式键入、模块源文件等。本章给出了在这些情况下使用的语法。

9.1. 完整的 Python 程序

虽然语言规范不需要规定如何调用语言解释器,但有一个完整的 Python 程序的概念是很有用的。一个完整的 Python 程序在一个最小初始化的环境中执行:所有内置和标准模块都可用,但除了 sys (各种系统服务), builtins (内置函数、异常和 None) 以及 __main__ 之外,都没有被初始化。后者用于为完整程序的执行提供局部和全局命名空间。

完整的 Python 程序的语法与下一节描述的文件输入的语法相同。

解释器也可以在交互模式下调用;在这种情况下,它不读取和执行一个完整的程序,而是一次读取和执行一条语句(可能是复合语句)。初始环境与完整程序的相同;每条语句都在 __main__ 的命名空间中执行。

一个完整的程序可以通过三种形式传递给解释器:使用 -c string 命令行选项,作为第一个命令行参数传递的文件,或作为标准输入。如果文件或标准输入是 tty 设备,则解释器进入交互模式;否则,它将执行该文件作为完整程序。

9.2. 文件输入

从非交互式文件读取的所有输入都具有相同的形式

file_input ::=  (NEWLINE | statement)*

此语法用于以下情况

  • 当解析一个完整的 Python 程序时(来自文件或字符串);

  • 当解析一个模块时;

  • 当解析传递给 exec() 函数的字符串时;

9.3. 交互式输入

交互模式下的输入使用以下语法进行解析

interactive_input ::=  [stmt_list] NEWLINE | compound_stmt NEWLINE

请注意,在交互模式下,(顶层)复合语句后面必须有一个空行;这是为了帮助解析器检测输入的结尾。

9.4. 表达式输入

eval() 用于表达式输入。它忽略前导空格。eval() 的字符串参数必须具有以下形式

eval_input ::=  expression_list NEWLINE*