码迷,mamicode.com
首页 > 编程语言 > 详细

python 2.7 中文教程 - 解释器

时间:2015-06-05 14:07:31      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:

调用python解释器

Python的解释器在linux上通常安装在/usr/bin/python,/usr/local/bin/python,/usr/local/bin/python等地方。Windows一般位于C:\Python27,且一般需要设置PATH环境变量。

#
root@localhost:[/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/


python 2.7 中文教程 - 解释器

标签:

原文地址:http://my.oschina.net/u/1433482/blog/425253

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!