16. 附录¶
16.1. 交互模式¶
16.1.1. 错误处理¶
当发生错误时,解释器会打印错误消息和堆栈跟踪。在交互模式下,它会返回到主提示符;当输入来自文件时,它会在打印堆栈跟踪后以非零退出状态退出。(由 except
子句在 try
语句中处理的异常在这种情况下不是错误。)一些错误是无条件的致命错误,会导致以非零退出状态退出;这适用于内部不一致和某些内存不足的情况。所有错误消息都写入标准错误流;从执行的命令输出的正常输出写入标准输出。
在主提示符或辅助提示符中键入中断字符(通常为 Control-C 或 Delete)会取消输入并返回到主提示符。 [1] 在命令执行期间键入中断会引发 KeyboardInterrupt
异常,该异常可以由 try
语句处理。
16.1.2. 可执行 Python 脚本¶
在 BSD 风格的 Unix 系统上,Python 脚本可以通过将以下行放在脚本开头,并赋予文件可执行模式,使其像 shell 脚本一样直接可执行。
#!/usr/bin/env python3
(假设解释器在用户的 PATH
中) #!
必须是文件的头两个字符。在某些平台上,这第一行必须以 Unix 风格的行结尾 ('\n'
) 结尾,而不是 Windows ('\r\n'
) 行结尾。请注意,井号或磅字符 '#'
用于在 Python 中开始注释。
可以使用 chmod 命令赋予脚本可执行模式或权限。
$ chmod +x myscript.py
在 Windows 系统上,没有“可执行模式”的概念。Python 安装程序会自动将 .py
文件与 python.exe
关联,以便双击 Python 文件会将其作为脚本运行。扩展名也可以是 .pyw
,在这种情况下,通常出现的控制台窗口会被抑制。
16.1.3. 交互式启动文件¶
当您以交互方式使用 Python 时,经常需要在每次启动解释器时执行一些标准命令。您可以通过将名为 PYTHONSTARTUP
的环境变量设置为包含启动命令的文件的名称来实现。这类似于 Unix shell 的 .profile
功能。
此文件仅在交互式会话中读取,而不是在 Python 从脚本读取命令时读取,也不是在 /dev/tty
被指定为命令的显式来源时读取(否则会像交互式会话一样)。它在执行交互式命令的相同命名空间中执行,因此它定义或导入的对象可以在交互式会话中无需限定符即可使用。您也可以在此文件中更改提示符 sys.ps1
和 sys.ps2
。
如果您想从当前目录读取额外的启动文件,您可以在全局启动文件中使用类似于 if os.path.isfile('.pythonrc.py'): exec(open('.pythonrc.py').read())
的代码来编程。如果您想在脚本中使用启动文件,您必须在脚本中显式地执行此操作。
import os
filename = os.environ.get('PYTHONSTARTUP')
if filename and os.path.isfile(filename):
with open(filename) as fobj:
startup_file = fobj.read()
exec(startup_file)
16.1.4. 自定义模块¶
Python 提供了两个钩子,让您可以自定义它:sitecustomize 和 usercustomize。要了解它的工作原理,您首先需要找到用户 site-packages 目录的位置。启动 Python 并运行以下代码
>>> import site
>>> site.getusersitepackages()
'/home/user/.local/lib/python3.x/site-packages'
现在,您可以在该目录中创建一个名为 usercustomize.py
的文件,并在其中放入任何您想要的内容。它将影响 Python 的每次调用,除非它是在使用 -s
选项启动时,禁用自动导入。
sitecustomize 的工作方式相同,但通常由计算机管理员在全局 site-packages 目录中创建,并在 usercustomize 之前导入。有关更多详细信息,请参阅 site
模块的文档。
脚注