16. 附录
********


16.1. 交互模式
==============

交互式 *REPL* 有两个变种版本。 经典的基本解释器在所有平台上受到支持，
具有最小化的行控制功能。

在 Windows 上，或在具有 "curses" 支持的类 Unix 系统上，默认会使用一个
新的交互式 shell。 它支持彩色、多行编辑、历史浏览和粘贴模式。 要禁用彩
色，请参阅 控制颜色 了解详情。 功能键将提供一些附加功能。 "F1" 是进入
交互式帮助浏览器 "pydoc"。 "F2" 允许浏览不带输出也不带 *>>>* 和 *...*
提示符的命令行历史。 "F3" 是进入“粘贴模式”，这可以更方便地粘贴大段代码
。 按 "F3" 将返回常规提示符。

当使用新的交互式 shell 时，可通过键入 "exit" 或 "quit" 退出 shell。 不
再需要在这些命令之后添加代表调用的圆括号。

如果不想要新的交互式 shell，可以通过 "PYTHON_BASIC_REPL" 环境变量禁用
它。


16.1.1. 错误处理
----------------

当发生错误时，解释器会打印错误消息和栈回溯。 在交互模式下，将返回到主
提示符；当输入是来自文件的时候，它将在打印栈回溯之后退出并附带一个非零
的退出状态码。 （由 "try" 语句中 "except" 子句所处理的异常在此上下文中
不属于错误。） 有些错误属于无条件致命错误，会导致程序附带非零状态码退
出；这适用于内部一致性丧失以及某些内存耗尽的情况等。 所有错误消息都将
被写入到标准错误流；来自被执行命令的正常输出测会被写入到标准输出。

将中断字符（通常为 "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" 显式作为被运行的 Python 脚本的文件名时（后者反而表现得像一
个交互式会话）。这个文件与交互式指令共享相同的命名空间，所以它定义或导
入的对象可以在交互式会话中直接使用。您也可以在该文件中更改提示符
"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" 模块的
文档。

-[ 备注 ]-

[1] GNU Readline 包的问题可能会阻止这种情况。
