python标准库sys_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() 为解释器设置最大递归深度

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值