python-sys模块

python-sys模块

"sys" 即 "system","系统"。该模块提供了一些接口,用于访问 Python 解释器自身使用和维护的变量 ,不是主机操作系统。

sys.argv    	#获取命令行参数列表,第一个元素是程序本身
sys.exit(n) 	#退出Python程序,exit(0)表示正常退出.	
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.version

返回python解释器的版本

import sys
print(sys.version)

3.8.10 | packaged by conda-forge | (default, Sep 13 2021, 21:12:34) [MSC v.1916 64 bit (AMD64)]

sys.argv

在解释器启动后, argv 列表包含了传递给脚本的所有参数, 列表的第一个元素为脚本自身的名称。

sys.argv[0] 表示程序自身
sys.argv[1] 表示程序的第一个参数
sys.argv[2] 表示程序的第二个参数

sys.platform

import sys
print(sys.platform)

win32     

sys.modules

返回系统导入的模块字段,key是模块名,value是模块

import sys
print(sys.modules.keys())

dict_keys(['sys', 'builtins', '_frozen_importlib', '_imp', '_warnings', '_io', 'marshal', 'nt', '_frozen_importlib_external', '_thread', '_weakref', 'winreg', 'time', 'zipimport', '_codecs', 'codecs', 'encodings.aliases', 'encodings', 'encodings.utf_8', '_codecs_cn', '_multibytecodec', 'encodings.gbk', '_signal', '__main__', 'encodings.latin_1', '_abc', 'abc', 'io', '_stat', 'stat', '_collections_abc', 'genericpath', 'ntpath', 'os.path', 'os', '_sitebuiltins', '_locale', '_bootlocale', '_distutils_hack', 'types', 'importlib._bootstrap', 'importlib._bootstrap_external', 'warnings', 'importlib', 'importlib.machinery', 'importlib.abc', '_operator', 'operator', 'keyword', '_heapq', 'heapq', 'itertools', 'reprlib', '_collections', 'collections', '_functools', 'functools', 'contextlib', 'importlib.util', 'google', 'mpl_toolkits', 'pywin32_system32', 'pywin32_bootstrap', 'qingstor', 'site'])

sys.path

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

当import某个模块时,Python会使用sys.path中指定目录,按顺序搜索导入的模块。如果没有找到,则汇报模块找不到错误。

import sys

print(sys.path)    # 返回的是一个列表,表示寻找包的路径


['e:\\gitcode\dataprocess\\test',
'D:\\X_software\\Code\\python\\Miniconda3\\envs\\dataans\\python38.zip', 		 'D:\\X_software\\Code\\python\\Miniconda3\\envs\\dataans\\DLLs', 'D:\\X_software\\Code\\python\\Miniconda3\\envs\\dataans\\lib', 
'D:\\X_software\\Code\\python\\Miniconda3\\envs\\dataans', 
'D:\\X_software\\Code\\python\\Miniconda3\\envs\\dataans\\lib\\site-packages', 'D:\\X_software\\Code\\python\\Miniconda3\\envs\\dataans\\lib\\site-packages\\win32', 'D:\\X_software\\Code\\python\\Miniconda3\\envs\\dataans\\lib\\site-packages\\win32\\lib', 'D:\\X_software\\Code\\python\\Miniconda3\\envs\\dataans\\lib\\site-packages\\Pythonwin']

可以通过append() 或者 insert() 方法加入自己的模块路径

import sys
from pathlib import Path

ROOT = Path(__file__).absolute().parent.parent   # 当前的文件的上两级目录
if str(ROOT) not in sys.path:
    sys.path.insert(0, str(ROOT))  # add ROOT to PATH

参考资料

https://www.jianshu.com/p/c1831232c391

https://www.cnblogs.com/hls-code/p/15337302.html

posted @ 2023-08-02 20:04  贝壳里的星海  阅读(34)  评论(0编辑  收藏  举报