zoukankan      html  css  js  c++  java
  • Python常用标准库之sys

    Python常用标准库之sys

    sys模块主要是针对与Python解释器相关的变量和方法,不是主机操作系统。
    导入方式:import sys

    sys.argv    #获取命令行参数列表,第一个元素是程序本身
    sys.exit(n) #退出Python程序,exit(0)表示正常退出。当参数非0时,会引发一个SystemExit异常,可以在程序中捕获该异常
    sys.version #获取Python解释程器的版本信息
    sys.maxsize #最大的Int值,64位平台是2**63 - 1
    sys.path    #返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
    sys.platform    #返回操作系统平台名称
    sys.stdin   #输入相关
    sys.stdout  #输出相关
    sys.stderr  #错误相关
    sys.exc_info()  #返回异常信息三元元组
    sys.getdefaultencoding()    #获取系统当前编码,默认为utf-8
    sys.setdefaultencoding()    #设置系统的默认编码
    sys.getfilesystemencoding() #获取文件系统使用编码方式,默认是utf-8
    sys.modules #以字典的形式返回所有当前Python环境中已经导入的模块
    sys.builtin_module_names    #返回一个列表,包含所有已经编译到Python解释器里的模块的名字
    sys.copyright   #当前Python的版权信息
    sys.flags   #命令行标识状态信息列表。只读。
    sys.getrefcount(object) #返回对象的引用数量
    sys.getrecursionlimit() #返回Python最大递归深度,默认1000
    sys.getsizeof(object[, default])    #返回对象的大小
    sys.getswitchinterval() #返回线程切换时间间隔,默认0.005秒
    sys.setswitchinterval(interval) #设置线程切换的时间间隔,单位秒
    sys.getwindowsversion() #返回当前windwos系统的版本信息
    sys.hash_info   #返回Python默认的哈希方法的参数
    sys.implementation  #当前正在运行的Python解释器的具体实现,比如CPython
    sys.thread_info #当前线程信息
    

    sys.argv

    sys.argv是一个脚本执行参数列表,列表的第一个元素是脚本名称,从第二个元素开始才是真正的参数。

    # test.py
    import sys
    
    for index, arg in enumerate(sys.argv):
        print("第%d个参数是: %s" % (index, arg))
    
    #输出
    第0个参数是: test.py
    第1个参数是: 1
    第2个参数是: 2
    第3个参数是: 3
    第4个参数是: 4 
    

    sys.path

    path是一个目录列表,供Python从中查找模块。在Python启动时,sys.path根据内建规则和PYTHONPATH变量进行初始化。sys.path的第一个元素通常是个空字符串,表示当前目录。

    >>> sys.path
    ['', 'C:\Python36\Lib\idlelib', 'C:\Python36\python36.zip', 'C:\Python36\DLLs', 'C:\Python36\lib', 'C:\Python36', 'C:\Python36\lib\site-packages']
    

    sys.path本质上是一个列表,可以进行append、insert、pop、remove等各种列表相关的操作,但通常都进行append操作,添加自己想要的查找路径。

    sys.stdin、sys.stdout、sys.stderr

    stdin用于所有的交互式输入(包括input()函数)。
    stdout用于print()的打印输出或者input()函数的提示符。
    stderr用于解释器自己的提示信息和错误信息。

    简而言之,这三个属性就是操作系统的标准输入、输出和错误流,它们返回的都是一个“文件类型”对象,支持read()、write()和flush()等操作,就像用open()方法打开的文件对象那样!

    >>> import sys
    >>> s = sys.stdin.read()        # 使用ctrl+d结束输入
    i like python
    end
    
    
    
    >>> s
    'i like python
    end
    
    
    
    '
    >>> sys.stdout.write(s)
    i like python
    end
    
    
    
    21
    

    sys.stdout 与 print()

    当我们用input('Please input something!')时,事实上是先输出提示信息,然后捕获输入。 以下两组等价:

    s = input('Please input something!')
    
    
    print('Please input something!',)  # 逗号表示不换行
    s = sys.stdin.readline()[:-1]  # -1 可以抛弃输入流中的'
    ' 换行符,自己琢磨一下为什么。
    

    sys.stdin 与 input()

    当我们print(obj)的时候,事实上是调用了sys.stdout.write(obj+' '),将内容打印到控制台(默认是显示器),然后追加一个换行符。以下两行等价:

    sys.stdout.write('hello'+'
    ') 
    print('hello')
    

    从控制台重定向到文件

    默认情况下sys.stdout指向控制台。如果把文件对象赋值给sys.stdout,那么print ()调用的就是文件对象的write()方法。

    f_handler = open('out.log', 'w') 
    sys.stdout = f_handler 
    print('hello')
    # 你无法在屏幕上看到“hello”
    # 因为它被写到out.log文件里了
    

    如果你还想同时在控制台打印的话,最好先将原始的控制台对象引用保存下来,向文件中打印之后再恢复 sys.stdout.

    __console__ = sys.stdout    # 保存控制台
    # redirection start #       # 去干点别的,比如写到文件里
    ... 
    # redirection end           # 干完别的了,恢复原来的控制台
    sys.stdout = __console__
    

    参考:

    转载内容,仅为个人学习使用,如有侵权,请联系删之。

  • 相关阅读:
    ASP.net MVC 构建layui管理后台(构造基础仓储)<1>
    ASP.net MVC 构建layui管理后台(整体效果)
    搭建私有 Nuget 服务器教程(1)
    SSAS数据集Cube不存在或者尚未处理
    浅谈MDX处理空值NULL及格式化结果
    Zoey.Dapper--Dapper扩展之把SQL语句放到文件中
    Polly每次重试执行不同的操作
    Exceptionless应用--自定义插件
    Fiddler开启Https的时候出现unable to configure windows to trust Fiddler Root certificate问题
    ASP.NET Core 中的配置
  • 原文地址:https://www.cnblogs.com/nykuo/p/13024262.html
Copyright © 2011-2022 走看看