美文网首页Python常用模块程序员
python标准库简介(一) sys模块

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

作者: 躺好别动 | 来源:发表于2018-03-23 17:10 被阅读77次

    在学习编程过程中,我一直遵循一个简单的思路,更好的写代码,写出更好的代码,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() 为解释器设置最大递归深度

    相关文章

      网友评论

        本文标题:python标准库简介(一) sys模块

        本文链接:https://www.haomeiwen.com/subject/fqvxcftx.html