python OS模块详解

时间:2021-08-20 22:38:21

os模块

  • 是和操作系统相关的模块

一、与文件有关的方法

(1)删除文件

  • 使用.remove()方法
os.remove(f) #删除文件

(2)重命名文件

  • 使用.rename()方法
os.rename(old,new) #重命名

(3)创建文件夹

  • 使用.mkdir().makedirs()方法
os.mkdir('python') #创建文件夹
os.makedirs('python2')

.mkdir().makedirs()区别

  • .mkdir()只能创建单层目录,且如果父目录不存在,直接创建子目录会报错
  • .makedirs()可以同时创建多层目录
#分别用他们2个创建一个2层的目录:  china/beijing
os.mkdir('china/beijing') #结果:报错
os.makedirs('china/beijing') #结果:创建成功

(4)删除空文件夹

  • 使用.removedirs()方法
os.removedirs('china') #结果:报错,因为China里面还有beijing文件夹

(5)获取到路径下的内容

  • 使用.listdir()方法,可以获得路径下第一层的文件夹和文件
print(os.listdir()) #显示该目录下的所有文件夹和文件
#如果不写路径,默认获取到的是当前路径下的所有文件夹和文件
print(os.listdir('e://')  #路径写成'e:\\'也可以

python OS模块详解

(6)几种判断方法

  • 判断是否是文件夹,使用.path.isdir()方法
print(os.path.isdir('f:\\2.工作'))#判断是否是文件夹
  • 判断是否是文件,使用.path.isfile()方法
print(os.path.isfile('笔记.py'))#判断是否是文件
  • 判断文件夹或文件是否存在,使用.path.exists()方法
print(os.path.exists('china'))#判断文件或者文件夹是否存在

使用.path.isdir().path.isfile()方法时,如果该文件(夹)不存在,结果显示为False;如果该文件(夹)不是文件夹,结果显示为False。因此这两种方法还可以判断文件(夹)是否存在。

 (7)循环获取路径、文件夹、文件

  • 使用.walk()方法,可以遍历取到当前路径以及路径中的所有路径、文件夹、文件
res=os.walk(r'F:\0.script repository\Python\jnz') #r表示后面是路径,“\”不转义    
python OS模块详解
res=os.walk(r'china')
for cur_path,dirs,files in res: #它有3个参数,分别代表当前目录、当前文件夹、当前文件
    print('当前目录',cur_path)
    print('当前文件夹',dirs)
    print('当前文件',files)
    print('---------------------------')
python OS模块详解

python OS模块详解

二、小练习

 1、统计一个路径下面有多少个python文件:

python OS模块详解
res = os.walk(r'F:\0.script repository\Python\jnz\day06\china')
count = 0
for cur_path, dirs, files in res:
    print('当前目录下面的所有文件', files)
    for i in files:
        if (i.endswith('.py')):
            count += 1

print('共有%d个Python文件' % count)
python OS模块详解

python OS模块详解

2、找到具有关键词的文件所在路径:

python OS模块详解
res = os.walk(r'F:\0.script repository\Python\jnz\day06\china')
count = 0
for cur_path, dirs, files in res:
    print('当前目录下面的所有文件', files)
    for f in files:
        if '.mp4' in f:
            print(cur_path) #找到.mp4所在路径
python OS模块详解

3、封装一个函数,传入路径和关键词,查找文件的路径:

python OS模块详解
#查找文件的路径
def find_file(path,keyword):
    res=os.walk(path)
    for cur_path,dirs,files in res:
        for file_name in files:
            if keyword in file_name:
                print('该文件在%s下面'%cur_path)

find_file('f:\\','测试用例模板.xls')
python OS模块详解

三、与操作系统命令有关的方法

 (1)执行操作系统命令

  • 1)使用.system()方法
os.system('ipconfig') #windows下查找ip
os.system('dir') #windows下查找当前路径
#在哪个操作系统下,.system里的变量就用哪个操作系统里的命令
  • 2)使用.popen()方法
os.popen('ipconfig') #windows下获取ip地址
  • 3)区别:

.system()无返回值,打印时获取不到命令的结果;.popen()可以获取到命令结果,但必须先调用.read()方法。

如果不需要返回命令结果,那直接使用.system()方法即可。

res=os.system('ipconfig')
print('res...',res)
#结果:res... 0
#0表示这条命令执行成功了,但打印不出该命令的结果
python OS模块详解
res2=os.popen('ipconfig').read() #获取结果要使用.read()读取后再打印,否则显示的是二进制编码
print(res2)
#结果: 
#res2... 
#Windows IP 配置
#
#
#以太网适配器 以太网:
#
#   媒体状态  . . . . . . . . . . . . : 媒体已断开连接
#  连接特定的 DNS 后缀 . . . . . . . : DHCP HOST
#
#无线局域网适配器 本地连接* 2:
...
python OS模块详解

(2)拼路径

  • 使用os.path.join()方法
print(os.path.join('china','a.py'))
#结果:china\a.py   windows下
#结果:china/a.py   linux下

该方法的优点是可以跨平台使用同一个命令。

(3)分割路径

  • 使用.os.path.split()方法,用于分割路径和文件(夹)名
res=os.path.split(r'china\beijing\haidian\changping\a.py')
print(res)
#结果为:('china\beijing\haidian\changping','a.py')

(4)取父目录

  • 使用os.path.dirname()方法
res=os.path.dirname(r'china\beijing\haidian\changping\a.py')
print(res)
#结果为:china\beijing\haidian\changping

(5)取文件大小

  • 使用os.path.getsize()方法,可以用该方法判断文件是否为空
print(os.path.getsize('笔记.txt'))
#结果为:839

(6)取当前的目录

  • 使用os.getcwd()方法
print(os.getcwd())
#结果为:C:\Users\jnz\day6

(7)进入另一个路径

  • 使用os.chdir()方法
python OS模块详解
res=os.getcwd() #取当前的目录
print(res)
#结果为:F:\0.script repository\Python\jnz\day06
print(os.chdir(r'F:\0.script repository\Python\jnz\day05'))#进入到哪个目录下
结果为:None
res=os.getcwd() #取当前的目录
print(res)
#结果为:F:\0.script repository\Python\jnz\day05
python OS模块详解

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
os.sep:取代操作系统特定的路径分隔符
os.name:指示你正在使用的工作平台。比如对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix'
os.getcwd:得到当前工作目录,即当前python脚本工作的目录路径。
os.getenv()和os.putenv:分别用来读取和设置环境变量
os.listdir():返回指定目录下的所有文件和目录名
os.remove(file):删除一个文件
os.stat(file):获得文件属性
os.chmod(file):修改文件权限和时间戳
os.mkdir(name):创建目录
os.rmdir(name):删除目录
os.removedirs(r“c:\python”):删除多个目录
os.system():运行shell命令
os.exit():终止当前进程
os.linesep:给出当前平台的行终止符。例如,Windows使用'\r\n',Linux使用'\n'而Mac使用'\r'
os.path.split():返回一个路径的目录名和文件名
os.path.isfile()和os.path.isdir()分别检验给出的路径是一个目录还是文件
os.path.existe():检验给出的路径是否真的存在
os.listdir(dirname):列出dirname下的目录和文件
os.getcwd():获得当前工作目录
os.curdir:返回当前目录('.'
os.chdir(dirname):改变工作目录到dirname
os.path.isdir(name):判断name是不是目录,不是目录就返回false
os.path.isfile(name):判断name这个文件是否存在,不存在返回false
os.path.exists(name):判断是否存在文件或目录name
os.path.getsize(name):或得文件大小,如果name是目录返回0L
os.path.abspath(name):获得绝对路径
os.path.isabs():判断是否为绝对路径
os.path.normpath(path):规范path字符串形式
os.path.split(name):分割文件名与目录(事实上,如果你完全使用目录,它也会将最后一个目录作为文件名而分离,同时它不会判断文件或目录是否存在)
os.path.splitext():分离文件名和扩展名
os.path.join(path,name):连接目录与文件名或目录
os.path.basename(path):返回文件名
os.path.dirname(path):返回文件路径

文件操作

1
2
os. mknod ( "text.txt" ):创建空文件
fp =  open ( "text.txt" ,w):直接打开一个文件,如果文件不存在就创建文件

关于open的模式

w 写方式
a 追加模式打开(从EOF开始,必要时创建新文件)
r+ 以读写模式打开
w+ 以读写模式打开
a+ 以读写模式打开
rb 以二进制读模式打开
wb 以二进制写模式打开 (参见 w )
ab 以二进制追加模式打开 (参见 a )
rb+ 以二进制读写模式打开 (参见 r+ )
wb+ 以二进制读写模式打开 (参见 w+ )
ab+ 以二进制读写模式打开 (参见 a+ )

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
fp. read ([size])   #size为读取的长度,以byte为单位
 
fp.readline([size])   #读一行,如果定义了size,有可能返回的只是一行的一部分
 
fp.readlines([size])   #把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。如果提供size参数,size是表示读取内容的总长,也就是说可能只读到文件的一部分。
 
fp.write(str)   #把str写到文件中,write()并不会在str后加上一个换行符
 
fp.writelines( seq )   #把seq的内容全部写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西。
 
fp.close()   #关闭文件。python会在一个文件不用后自动关闭文件,不过这一功能没有保证,最好还是养成自己关闭的习惯。 如果一个文件在关闭后还对其进行操作会产生ValueError
 
fp.flush()   #把缓冲区的内容写入硬盘
 
fp.fileno()   #返回一个长整型的”文件标签“
 
fp.isatty()   #文件是否是一个终端设备文件(unix系统中的)
 
fp.tell()   #返回文件操作标记的当前位置,以文件的开头为原点
 
fp.next()   #返回下一行,并将文件操作标记位移到下一行。把一个file用于for … in file这样的语句时,就是调用next()函数来实现遍历的。
 
fp.seek(offset[,whence])   #将文件打操作标记移到offset的位置。这个offset一般是相对于文件的开头来计算的,一般为正数。但如果提供了whence参数就不一定了,whence可以为0表示从头开始计算,1表示以当前位置为原点计算。2表示以文件末尾为原点进行计算。需要注意,如果文件以a或a+的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾。
 
fp.truncate([size])   #把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。
 
目录操作
 
os. mkdir ( "file" )  创建目录
 
shutil.copyfile( "oldfile" , "newfile" )  复制文件:oldfile和newfile都只能是文件
 
shutil.copy( "oldfile" , "newfile" )  oldfile只能是文件夹,newfile可以是文件,也可以是目标目录
 
shutil.copytree( "olddir" , "newdir" )  复制文件夹.olddir和newdir都只能是目录,且newdir必须不存在
 
os.rename( "oldname" , "newname" )  重命名文件(目录).文件或目录都是使用这条命令
 
shutil.move( "oldpos" , "newpos" )  移动文件(目录)
 
os. rmdir ( "dir" )  只能删除空目录
 
shutil.rmtree( "dir" )  空目录、有内容的目录都可以删
 
os.chdir( "path" )  转换目录,换路径