调用python解释器
Python的解释器在linux上通常安装在/usr/bin/python,/usr/local/bin/python,/usr/local/bin/python等地方。Windows一般位于C:\Python27,且一般需要设置PATH环境变量。
# [email protected]:[/root]#python Python 2.7.5 (default, Jun 17 2014, 18:11:42) [GCC 4.8.2 20140120 (Red Hat 4.8.2-16)] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>>
退出解释器:Linux上Control-D,Windows上Control-Z,统一的方式:quit()。
解释器的行编辑功能并不复杂。在Unix上,解释器可能已启用了GNU readline库,它增加了更多的交互编辑和历史记录功能。输入Control-P,如果发出哔哔声表示支持readline;见附录交互式输入编辑和历史替换https://docs.python.org/2/tutorial/interactive.html#tut-interacting。
解释器的操作有些像Unix Shell:当标准输入连接到tty设备时,它读取并以交互方式执行命令;当文件名参数或以文件作为标准输入设备时,它读取并执行文件中脚本。 有 启动解释器的第二个方法是python -c command [arg] ...,执行command中的语句,等同于Shell的-c选项。因为Python语句通常会包括空格或其他shell的特殊字符是特殊的外壳,建议使把command放在单引号中。
一些Python模块也作为脚本使用:python -m module [arg] ...。
使用脚本文件时,-i参数可以进入交互模式。
参数传递
脚本名和附加参数转换成字符串列表传递给sys模块中的argv变量。您可以通过执行导入系统访问这个列表。列表的长度是一,在无脚本无参数时,sys.argv中[0]是一个空字符串。当脚本名为"-"(意思是标准输入),sys.argv中[0]为"-"。使用-c参数时,sys.argv中[0]设置为‘-c‘。i使用-m参数sys.argv中[0]设置为模块的全名。-c或-m之后的选项不为Python解释器的选项处理消耗处理,但留在sys.argv中留待命令或模块来处理。
交互模式
当tty读取命令时解释器为交互模式。主命令提示符为(>>>),从命令提示符(...)用于续行。
#python Python 2.7.5 (default, Jun 17 2014, 18:11:42) [GCC 4.8.2 20140120 (Red Hat 4.8.2-16)] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> the_world_is_flat = 1 >>> if the_world_is_flat: ... print "Be careful not to fall off!" ... Be careful not to fall off! >>>
解释器及其环境
错误处理
当错误发生时,解释器打印错误信息和栈跟踪。在交互模式下,它返回主提示符;在文件输入时,打印栈跟踪器后以非零退出状态退出。有些错误致命的,无条件以非零退出的退出,比如内部不一致和内存耗尽。所有的错误信息都写入标准错误流;正常输出写入标准输出。
输入中断符(通常是Control-C或DEL)可以取消输入,命令执行时输入中断引发一个KeyboardInterrupt异常。
执行python脚本
Linux系统中,Python脚本可直接执行,就像shell脚本,在文件首行添加如下:
#! /usr/bin/env python
并添加可执行权限:
chmod +x myscript.py
Windows系统中Python的安装程序会自动关联*.py到python.exe,双击即可运行。*.pyw则不会出现windows控制台。
源码编码
使用的编码ASCII以外的字符Python的源文件,可以在行#!之后定义源文件编码:
# -*- coding: encoding -*-
根据这个声明,源文件中的所有字符将用该编码的编码,并可能在用选定的编码书写Unicode字符串。编码列表可以在Python库参考手册的codecshttps://docs.python.org/2/library/codecs.html#module-codecs部分找到。实例:
# -*- coding: iso-8859-15 -*-currency = u"€"print ord(currency)
一般推荐使用utf-8的格式,在网络上比较通用,特殊的中文处理可以使用gbk。为了正确显示所有的字符,编辑器必须支持utf-8等格式,并有相应的字体。
交互式启动文件
交互式使用Python的时候,常常需要在解释器启动时执行一些标准命令。可设置环境变量PYTHONSTARTUP表示启动命令文件,类似Unix shell的.profile文件。
文件只对交互会话有效,当 Python 从脚本中读取命令或以终端/dev/tty做为外部命令源(行为和交互式会话类似)。它与解释器执行的命令在同一命名空间,这样它定义或导入的对象可以在 解释器中使用。也可以在这个文件中改变提示符sys.ps1和sys.ps2。
加载其他文件的方式: if os.path.isfile(‘.pythonrc.py‘): execfile(‘.pythonrc.py‘) 。在脚本中使用启动文件如下:
import osfilename = os.environ.get(‘PYTHONSTARTUP‘)if filename and os.path.isfile(filename): execfile(filename)
自定义模块
Python有两个hook: sitecustomize 和 usercustomize。使用它们首先需要知道site-packages目录,方法如下:
>>> import site >>> site.getusersitepackages() ‘/root/.local/lib/python2.7/site-packages‘
现在你可以在site-packages的目录下创建文件usercustomize.py,放入你想添加的任何内容。 该文件会影响 python 的每次调用,除非启动的时候加入-s选项禁止自动导入。
类似的有sitecustomize,但是一般由管理员在全局site-packages创建,在usercustomize之前导入,更多资料参见site模块https://docs.python.org/2/library/site.html#module-site。
联系作者:徐荣中 python开发自动化测试群113938272 微博 http://weibo.com/cizhenshi。
原英文地址:https://docs.python.org/2/tutorial/