在学习编程过程中,我一直遵循一个简单的思路,更好的写代码,写出更好的代码,python作为我的主要开发工具,有必要深入了解下python标准库.
- 更好的利用标准库中已经有的轮子,提升自己的开发效率.
- 标准库的源码一定是最pythonic,学习其pythonic的编码风格.
该系列文章全部基于python3.5,交互式环境全都基于Ipython 5.1.0
文章采用标准库常用功能介绍,源码分析(挑选重要的),应用场景介绍(工程实践较少,见谅^^)为组织方式.
sys模块
sys模块是最常用的和python解释器交互的模块,sys模块可供访问由解释器(interpreter)使用或维护的变量和与解释器进行交互的函数。
sys.argv
程序外部向程序内部传递参数
test_argv.py
import sys
print(sys.argv)
print(sys.argv[0])
print(sys.argv[1])
$ python3 test_argv.py hello
['test_argv.py', 'hello']
test.py
hello
sys.argv 是一个列表对象,第一个元素永远是文件名,接下来依次是传入的参数,大家可以动手实验多加几个参数.
这样就实现了在运行python脚本的时候从terminal往脚本里面传递参数
sys.path/sys.module
- sys.path 解释器来搜索python包的路径,sys.path[0]是该py文件的路径
- sys.modules 一个已加载模块的字典
In [1]: import sys
In [2]: sys.path
Out[2]:
['',
'/usr/lib/python35.zip',
'/usr/lib/python3.5',
'/usr/lib/python3.5/plat-x86_64-linux-gnu',
'/usr/lib/python3.5/lib-dynload',
'/home/zhangwenchao/.local/lib/python3.5/site-packages',
'/usr/local/lib/python3.5/dist-packages',
'/usr/lib/python3/dist-packages',
'/usr/lib/python3/dist-packages/IPython/extensions',
'/home/zhangwenchao/.ipython']
写好的py文件放在以上目录下就可以被python解释器搜索到,也可以这样
sys.path.append('文件路径')给解释器增加搜索包的路径
In [3]: sys.modules
Out[3]:
{'IPython': <module 'IPython' from '/usr/lib/python3/dist-packages/IPython/__init__.py'>,
'IPython.core': <module 'IPython.core' from '/usr/lib/python3/dist-packages/IPython/core/__init__.py'>,
'IPython.core.alias': <module 'IPython.core.alias' from '/usr/lib/python3/dist-packages/IPython/core/alias.py'>,
'IPython.core.application': <module 'IPython.core.application' from '/usr/lib/python3/dist-packages/IPython/core/application
......
}
sys.modules是一个全局字典 python启动后自动加载的全局变量,导入新的模块会自动更新到这个字典中.删除该字典可能会导致python不能正确运行.
sys.exit(n)
python解释器一般在执行到py文件末尾的时候自动退出,主动调用sys.exit()可以在中途退出
test.py
import sys
print('1111111')
print('2222222')
sys.exit(1)
print('3333333')
print('4444444')
$ python3 test.py
1111111
2222222
本来应该打印的3333333和4444444没有打印,执行到sys.exit()的时候就退出了,这和python解释器执行到文件末尾退出是一样的,下面代码具有相同的效果
test.py
print('1111111')
print('2222222')
raise SystemExit
print('3333333')
print('4444444')
sys.exc_info()
sys.exc_info()可以获得当前错误的详细信息
test.py
import sys
def err():
raise NameError('name error')
try:
err()
except Exception as e:
print(e)
exc_type, exc_value, exc_traceback_obj = sys.exc_info()
print(exc_type)
print(exc_value)
print(exc_traceback_obj)
$python3 test.py
name error
<class 'NameError'>
name error
<traceback object at 0x7f1e9ba611c8>
sys 还可以对解释器的错误堆栈追踪进行详细信息的设置
python解释器相关
- sys.api_version 解释器的C的API版本
- sys.copyright 版权信息
- sys.platform 解释器运行的平台,我的是linux
- sys.version 解释器的python版本
- sys.getrecursionlimit() 解释器的最大递归深度,默认为1000
- setrecursionlimit() 为解释器设置最大递归深度