zoukankan      html  css  js  c++  java
  • python OS模块详解

    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:\'也可以

    (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:.script repositoryPythonjnz') #r表示后面是路径,“”不转义    
    复制代码
    res=os.walk(r'china')
    for cur_path,dirs,files in res: #它有3个参数,分别代表当前目录、当前文件夹、当前文件
        print('当前目录',cur_path)
        print('当前文件夹',dirs)
        print('当前文件',files)
        print('---------------------------')
    复制代码

    二、小练习

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

    复制代码
    res = os.walk(r'F:.script repositoryPythonjnzday06china')
    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)
    复制代码

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

    复制代码
    res = os.walk(r'F:.script repositoryPythonjnzday06china')
    count = 0
    for cur_path, dirs, files in res:
        print('当前目录下面的所有文件', files)
        for f in files:
            if '.mp4' in f:
                print(cur_path) #找到.mp4所在路径
    复制代码

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

    复制代码
    #查找文件的路径
    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')
    复制代码

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

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

    (2)拼路径

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

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

    (3)分割路径

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

    (4)取父目录

    • 使用os.path.dirname()方法
    res=os.path.dirname(r'chinaeijinghaidianchangpinga.py')
    print(res)
    #结果为:chinaeijinghaidianchangping

    (5)取文件大小

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

    (6)取当前的目录

    • 使用os.getcwd()方法
    print(os.getcwd())
    #结果为:C:Usersjnzday6

    (7)进入另一个路径

    • 使用os.chdir()方法
    复制代码
    res=os.getcwd() #取当前的目录
    print(res)
    #结果为:F:.script repositoryPythonjnzday06
    print(os.chdir(r'F:.script repositoryPythonjnzday05'))#进入到哪个目录下
    结果为:None
    res=os.getcwd() #取当前的目录
    print(res)
    #结果为:F:.script repositoryPythonjnzday05
    复制代码
    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使用' ',Linux使用' '而Mac使用' '
    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")  转换目录,换路径

      

    没有借口
  • 相关阅读:
    Codeforces Beta Round #17 A
    Codeforces Round #382 (Div. 2) D. Taxes 哥德巴赫猜想
    Codeforces Round #382 (Div. 2)C. Tennis Championship 动态规划
    Codeforces Round #382 (Div. 2)B. Urbanization 贪心
    Codeforces Round #382 (Div. 2) A. Ostap and Grasshopper bfs
    Codeforces Beta Round #80 (Div. 2 Only)【ABCD】
    Codeforces Beta Round #62 题解【ABCD】
    Codeforces Round #160 (Div. 1) 题解【ABCD】
    Codeforces Round #383 (Div. 2) 题解【ABCDE】
    Codeforces Round #271 (Div. 2)题解【ABCDEF】
  • 原文地址:https://www.cnblogs.com/wutao1935/p/11121438.html
Copyright © 2011-2022 走看看