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