python标准库简介(一) sys模块

在学习编程过程中,我一直遵循一个简单的思路,更好的写代码,写出更好的代码,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': ,
 'IPython.core': ,
 'IPython.core.alias': ,
 '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

name error

sys 还可以对解释器的错误堆栈追踪进行详细信息的设置

python解释器相关

  • sys.api_version 解释器的C的API版本
  • sys.copyright 版权信息
  • sys.platform 解释器运行的平台,我的是linux
  • sys.version 解释器的python版本
  • sys.getrecursionlimit() 解释器的最大递归深度,默认为1000
  • setrecursionlimit() 为解释器设置最大递归深度

你可能感兴趣的:(python标准库简介(一) sys模块)