Python标准库中的OS模块,提供一种可移植的方式(程序与平台无关)来使用依赖于操作系统的功能。简而言之,os模块提供了许多能够直接操纵不同的操作系统的Python接口。一个操作系统所能提供的常用命令行接口,在os模块中基本都能做到。本篇主要是对os模块中常用属性和方法的记录。想了解更详细的使用推荐使用Python中文文档,点这里。
操作系统相关模块的名字。目前已经注册以下的名字:’posix’、’nt’、’os2’、’ce’、’java’、’riscos’。
如果执行平台是window,则os.name == "nt"
,如果是Linux/Unix,则os.name == 'posix'
。
>>> os.name
'posix'
POSIX :表示可移植操作系统接口(Portable Operating System Interface ,缩写为 POSIX ),POSIX标准定义了操作系统应该为应用程序提供的接口标准,是IEEE为要在各种UNIX操作系统上运行的软件而定义的一系列API标准的总称,其正式称呼为IEEE 1003,而国际标准名称为ISO/IEC 9945。
也称之为换行符,windows下为”\t\n”,Linux下为”\n
>>> os.linesep
'\n'
目录层之间的分隔符
>>> os.sep
'/'
>>> os.pathsep
':'
root@localhost workspace]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/opt/workspace:/root/bin #在Linux中路径以':'来分隔
os.curdir 返回当前目录: (‘.’)
os.pardir 获取当前目录的父目录字符串名:(‘..’)
os.R_OK/os.W_OK/os.X_OK 文件权限模式。他们的值分别是:4/2/1
os.environ 获取系统环境变量
获取当前工作目录的绝对路径。
>>> os.getcwd()
'/opt/workspace'`
如果path存在,返回True;如果path不存在,返回False。常用于在对一个文件做操作之前的判断依据。
>>> os.path.exists("/opt/workspace/tab.py")
True
是返回True,否则False
>>> os.path.isfile("tab.py")
True
>>> os.path.isfile("testMkdir")
False
是True,否则False。
>>> os.path.isdir("testMkdir")
True
>>> os.path.isdir("tab.py")
False
生成一个包含两个元素的元组。
>>> os.path.split("/opt/workspace/tab.py")
('/opt/workspace', 'tab.py') #tab.py为文件
>>> os.path.split("/opt/workspace/testMkdir") #testMkdir为目录
('/opt/workspace', 'testMkdir')
就是os.path.split(path)的第一个元素
>>> os.path.dirname("/opt/workspace/tab.py") # 本质 == os.path.split("/opt/workspace/tab.py")[0]
'/opt/workspace'
即os.path.split(path)的第二个元素。
注意:如何路径以’/’或’\’结尾,就会返回空值。
>>> os.path.basename("/opt/workspace/tab.py") #本质 == os.path.split("/opt/workspace/tab.py")[1]
'tab.py'
>>> os.path.basename("/opt/workspace/testMkdir")
'testMkdir'
>>> os.path.basename("/opt/workspace/")
''
>>> os.path.basename("/opt/workspace/tab.py")
'tab.py'
>>> os.path.dirname("/opt/workspace/tab.py")
'/opt/workspace'
>>> os.path.join(os.path.dirname("/opt/workspae/tab.py"),os.path.basename("/opt/workspace/tab.py"))
'/opt/workspae/tab.py'
>>> os.path.splitext("tab.py")
('tab', '.py')
返回一个文件或目录的绝对路径,可以很方便的得到一个文件或目录的绝对路径。
>>> os.path.abspath("tab.py")
'/opt/workspace/tab.py'
>>> os.path.getsize("tab.py")
417
>>> os.path.getsize("testMkdir")
6
>>> os.stat("/opt")
posix.stat_result(st_mode=16877, st_ino=164, st_dev=64768L, st_nlink=4, st_uid=0, st_gid=0, st_size=31, st_atime=1460805310, st_mtime=1460805067, st_ctime=1460805067)
>>> os.stat("/opt/workspace/tab.py")
posix.stat_result(st_mode=33152, st_ino=203490123, st_dev=64768L, st_nlink=1, st_uid=0, st_gid=0, st_size=417, st_atime=1460805594, st_mtime=1460805500, st_ctime=1460805500)
listdir(…)
listdir(path) -> list_of_strings
Return a list containing the names of the entries in the directory.
path: path of directory to list
The list is in arbitrary order.
NOTE:It does not include the special
entries ‘.’ and ‘..’ even if they are present in the directory.
注意:路径并不能含有’.’ or ‘..’ 。
>>> dirName = "/opt/workspace"
>>> os.listdir(dirName)
['ifTest.py', 'forTest.py', 'forTest1.py', 'whileTest.py', 'continueTest.py', 'pyModule.py', 'randomTest.py', 'funcTest1.py', '.servStatus.py.swp', 'forTest2.py', 'ifTest1.py', 'pyModule.pyc', 'tab.py', 'tab.pyc', 'choiceTest.py', 'funTest2.py', 'funcTest3.py']
os.walk(top[, topdown=True[, onerror=None[, followlinks=False]]])
1.top表示要遍历的目录树的路径
2.topdown的默认值是”True”,表示首先返回目录树下的文件,然后在遍历目录树的子目录.Topdown的值为”False”时,则表示先遍历目录树的子目录,返回子目录下的文件,最后返回根目录下的文件
3.onerror的默认值是”None”,表示忽略文件遍历时产生的错误。如果不为空,则提供一个自定义函数提示错误信息后继续遍历或抛出异常中止遍历
for root, dirs, files in os.walk("/opt", topdown=False):
for name in files:
print(os.path.join(root, name)) #打印文件绝对路径
for name in dirs:
print(os.path.join(root, name)) #打印目录绝对路径
1.top表示需要遍历的目录树的路径
2.func表示回调函数,对遍历路径进行处理.所谓回调函数,是作为某个函数的参数使用,当某个时间触发时,程序将调用定义好的回调函数处理某个任务.回调函数必须提供3个参数:第1个参数为walk()的参数tag,第2个参数表示目录列表,第3个参数表示文件列表
3.arg是传递给回调参数func的元组.回调函数的一个参数必须是arg,为回调函数提供处理参数.参数arg可以为空
def visitDir(arg,dirname,names):
for filespath in names:
print os.path.join(dirname,filespath)
path="/opt"
os.path.walk(path,VisitDir,())
注意:os.path.walk()与os.walk()产生的文件名列表并不相同。os.path.walk()产生目录树下的目录路径和文件路径,而os.walk()只产生文件路径
>>> os.mkdir("testMkdir")
>>> os.listdir(os.getcwd())
['tab.py', 'ipython-4.1.2.tar.gz', 'ipython-4.1.2', 'traitlets-4.1.0', 'ipython_genutils-0.1.0', 'pexpect-4.0.1', 'ptyprocess-0.5', 'pickleshare-0.5', 'path.py-8.1.1', 'testMkdir']
>>> os.makedirs("/opt/workspace/dirname1/dirname2")
>>> os.listdir("/opt/workspace")
['tab.py', 'ipython-4.1.2.tar.gz', 'ipython-4.1.2', 'traitlets-4.1.0', 'ipython_genutils-0.1.0', 'pexpect-4.0.1', 'ptyprocess-0.5', 'pickleshare-0.5', 'path.py-8.1.1', 'testMkdir', 'dirname1']
>>> os.rmdir("testDir")
若dirname2为空,则删除,并递归到上一级dirname1目录,如若也为空,则也删除,依此类推。
>>> os.removedirs("/opt/workspace/dirname1/dirname2")
注意:只能够删除文件,而不能删除一个目录。
>>> os.remove('ifTest.py')
>>> os.rename("test","JustTest") #test为一个文件
>>> os.rename("ipython-4.1.2","sdasd") #ipython-4.1.2为一个目录
>>> os.getcwd()
'/opt/workspace'
>>> os.chdir("/")
>>> os.getcwd()
'/'
可以执行不同平台下的Shell指令,显示执行结果并返回执行状态。若为Windows,则为CMD;若是Linux,则为Bash。
注意:返回的是执行状态,执行结果只会显示在终端上。
os.system(…)
os.system(command) -> exit_status
Execute the command (a string) in a subshell.
>>> result = os.system("ls")
ipython-4.1.2.tar.gz path.py-8.1.1 ptyprocess-0.5 testMkdir
ipython_genutils-0.1.0 pexpect-4.0.1 sdasd traitlets-4.1.0
JustTest pickleshare-0.5 tab.py
>>> result
生成的变量可以赋给变量,再用read()等类文件对象内置方法读取和操作。
>>> result = os.popen("ls")
>>> result.read()
'ipython-4.1.2.tar.gz\nipython_genutils-0.1.0\nJustTest\npath.py-8.1.1\npexpect-4.0.1\npickleshare-0.5\nptyprocess-0.5\nsdasd\ntab.py\ntestMkdir\ntraitlets-4.1.0\n'
>>> stinfo = os.stat("/opt/workspace/tab.py")
>>> stinfo.st_atime
1460805594.4710202
>>> stinfo.st_mtime
1460805500.175018
>>>os.utime('/opt/workspace/tab.py',(1375448978,1369735977))
>>> stinfo = os.stat("/opt/workspace/tab.py")
>>> stinfo.st_atime
1375448978.0
>>> stinfo.st_mtime
1369735977.0
一般需要结合os.R_OK/os.W_OK/os.X_OK文件权限模式来处理。
>>> os.access("tab.py",os.W_OK)
True
>>> os.access("tab.py",os.R_OK)
True
>>> os.access("tab.py",os.X_OK)
False
>>> os.chmod("tab.py",os.X_OK)
>>> os.access("tab.py",os.X_OK)
True
os.path.commonprefix(list) 返回list中,所有path共有的最长的路径,从左向右,相同字符
os.path.abspath(path) 返回path规范化的绝对路径
os.path.isabs(path) 如果path是绝对路径,返回True
os.path.normcase(path) 在Linux下,该函数会原样返回path,在windows平台上会将路径中所有字符转换为小写,并将所有斜杠转换为反斜杠