先把常用命令粘出来方便查看
标准自带模块,不需要安装
sys.argv 命令行参数List,第一个元素是程序本身路径
sys.getdefaultencoding(): 获取系统当前编码,一般默认为ascii。
sys.setdefaultencoding(): 设置系统默认编码,执行dir(sys)时不会看到这个方法,在解释器中执行不通过,可以先执行reload(sys),在执行 setdefaultencoding('utf8'),此时将系统默认编码设置为utf8。(见设置系统默认编码 )。
sys.getfilesystemencoding(): 获取文件系统使用编码方式,Windows下返回'mbcs',mac下返回'utf-8'.
sys.modules.keys() 返回所有已经导入的模块列表
sys.exc_info() 获取当前正在处理的异常类,exc_type、exc_value、exc_traceback当前处理的异常详细信息
sys.exit(n) 退出程序,正常退出时exit(0)
sys.hexversion 获取Python解释程序的版本值,16进制格式如:0x020403F0
sys.version 获取Python解释程序的版本信息
sys.maxint 最大的Int值
sys.maxunicode 最大的Unicode值
sys.modules 返回系统导入的模块字段,key是模块名,value是模块
sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
sys.platform 返回操作系统平台名称
sys.stdout 标准输出
sys.stdin 标准输入
sys.stderr 错误输出
sys.exc_clear() 用来清除当前线程所出现的当前的或最近的错误信息
sys.exec_prefix 返回平台独立的python文件安装的位置
sys.byteorder 本地字节规则的指示器,big-endian平台的值是'big',little-endian平台的值是'little'
sys.copyright 记录python版权相关的东西
sys.api_version 解释器的C的API版本
环境
python3.6
如果是在linux上直接运行就好,如果是Windows上请安装pycharm。
使用pycharm直接RUN运行是不行的,需要调出终端命令行来运行,点击左下角PEP,选择Terminal,如图所示:
示例:
sys.argv()
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys
print(sys.argv[0])
print(sys.argv[1])
结果:
F:\python_test>python sys_test.py 20170920
sys_test.py
20170920
或者终端命令行直接运行:
python -c "import sys;print(sys.argv[0]);print(sys.argv[1])" arg1
结果:
F:\python_test>python -c "import sys;print(sys.argv[0]);print(sys.argv[1])" arg1
-c
arg1
sys.exit()
0是正常退出,其他为异常
import sys
def exitfunc(value):
print(value)
sys.exit(0)
print("hello")
try:
sys.exit(1)
except SystemExit as value:
exitfunc(value)
print("come?")
结果:
hello
1
先打印hello,在执行exit(1),抛异常把1传给values,values在传进函数中执行,打印1退出。
注:
python版本2和版本3的抛异常不一样
python2中except SystemExit,value:
python3中except SystemExit as value:
sys.path
import sys
print(sys.path)
结果:
['F:\\python_test', 'F:\\python_test\\sys_test.py', 'F:\\anaconda3\\python36.zip', 'F:\\anaconda3\\DLLs', 'F:\\anaconda3\\lib', 'F:\\anaconda3', 'F:\\anaconda3\\lib\\site-packages', 'F:\\anaconda3\\lib\\site-packages\\Sphinx-1.5.1-py3.6.egg', 'F:\\anaconda3\\lib\\site-packages\\win32', 'F:\\anaconda3\\lib\\site-packages\\win32\\lib', 'F:\\anaconda3\\lib\\site-packages\\Pythonwin', 'F:\\anaconda3\\lib\\site-packages\\setuptools-27.2.0-py3.6.egg']
写好的模块可以放在上面的某个路径,就可以正常的搜到了。
在import导入module_name时,就是根据sys.path的路径来搜索module.name,也可以自定义添加模块路径。
sys.path.append("自定义模块路径")
sys.modules
全局字典,每当python启动时该字段自动加载到内存中。新加模块sys.modules会自动记录该模块,第二次导入时直接从字典中加载,加快运行速度。他拥有字典的一切方法。
keys是模块名
values是模块
modules返回路径
import sys
print(sys.modules.keys())
print("``````````````")
print(sys.modules.values())
print("```````````````````")
print(sys.modules["os"]
结果:
dict_keys(['builtins', 'sys', '_frozen_importlib', '_imp', '_warnings', '_thread', '_weakref', '_frozen_importlib_external', '_io', 'marshal', 'nt', 'winreg', 'zipimport', 'encodings', 'codecs', '_codecs', 'encodings.aliases', 'encodings.utf_8', '_signal', '__main__', 'encodings.latin_1', 'io', 'abc', '_weakrefset', 'site', 'os', 'errno', 'stat', '_stat', 'ntpath', 'genericpath', 'os.path', '_collections_abc', '_sitebuiltins', 'sysconfig', '_bootlocale', '_locale', 'encodings.gbk', '_codecs_cn', '_multibytecodec', 'types', 'functools', '_functools', 'collections', 'operator', '_operator', 'keyword', 'heapq', '_heapq', 'itertools', 'reprlib', '_collections', 'weakref', 'collections.abc', 'encodings.cp437'])
--------------
dict_values([, , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ])
--------------
sys.stdin\stdout\stderr
Python程序的标准输入/输出/出错流定义在sys模块中,分别 为: sys.stdin, sys.stdout, sys.stderr
标准输入输出:
import sys
print('Hi, %s!' % input('Please enter your name:'))
python2的raw_input和python3的input
结果:
F:\anaconda3\python.exe F:/python_test/sys_test.py
Please enter your name:ly
Hi, ly!
stdin
程序效果同上:
print('Please enter your name:',)
name=sys.stdin.readline()[:-1]
print('Hi, %s!' % name)
结果:
Please enter your name:
lc
Hi, lc!
stdout
sys.stdout.write('Hello World!')
与
print('Hello World!')
结果:
Hello World!
打印sys.stdin, sys.stdout, sys.stderr
import sys
for f in (sys.stdin, sys.stdout, sys.stderr):
print(f)
结果:
<_io.TextIOWrapper name='' mode='r' encoding='UTF-8'>
<_io.TextIOWrapper name='' mode='w' encoding='UTF-8'>
<_io.TextIOWrapper name='' mode='w' encoding='UTF-8'>
可以看出stdin, stdout, stderr在Python中无非都是文件属性的对象,他们在Python启动时自动与Shell 环境中的标准输入,输出,出错关联。
而Python程序的在Shell中的I/O重定向与DOS命令的重定向完全相同,其实这种重定向是由Shell来提供的,与Python 本身并无关系。那么我们是否可以在Python程序内部将stdin,stdout,stderr读写操作重定向到一个内部对象呢?答案是肯定的。
Python提供了一个StringIO模块来完成这个设想,比如:
重定向到一个内部对象
可以在Python程序内部将stdin,stdout,stderr读写操作重定向到一个内部对象,使用StringIO模块。
import sys
from io import StringIO
import sys
buff =StringIO()
temp = sys.stdout #保存标准I/O流
sys.stdout = buff #将标准I/O流重定向到buff对象
print(42, 'hello', 0.001)
sys.stdout =temp #恢复标准I/O流
print(buff.getvalue())
StringIO模块在python自带
python2.x中from StringIO import String
还有一个用c实现的比他还快from cStringIO import StringIO
python3.x中,StringIO在io模块中了from io import StringIO
结果:
42 hello 0.001
reload
对已经加载过得模块进行重新加载,一般原模块有变化等特殊情况,reload前该模块必须已经import过.
原来已经使用的实例还是会使用旧模块,而新生产的实例会使用新的模块,reload后还是用原来的内存地址。
import os
reload(os)
特例:
import sys
sys.setdefaultencoding('utf8')
引用会出错,因为setdefaultencoding函数在被系统调用后被删除了,所以通过import引用进来时其实已经没有了,所以必须reload一次sys模块,这样setdefaultencoding才会为可用,
import sys
reload(sys)
sys.setdefaultencoding('utf8')
del sys.setdefaultencoding ##删除原来的setdefaultencoding函数
sys.setdefaultencoding('gb2312')
python安装目录的Lib文件夹下,有一个叫site.py的文件【python2.6】,在里面可以找到main() --> setencoding()-->sys.setdefaultencoding(encoding),因为这个site.py每次启动python解释器时会自动加载,所以main函数每次都会被执行,setdefaultencoding函数一出来就已经被删除了。