• Python之sys & os


    os模块:

     •  负责程序与操作系统的交互,提供了访问操作系统底层的接口

    一、与文件有关的方法

    (1)删除文件

        •  使用.remove()方法

    os.remove(‘f’) #删除文件
    os.rmdir('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()和 .rmdir() 方法

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

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

       •  使用.listdir()方法,可以取到指定路径下第一层的文件夹和文件

    print(os.listdir()) #显示该目录下的所有文件夹和文件
    #如果不写路径,默认获取到的是当前路径下的所有文件夹和文件
    
    print(os.listdir('..')  #路径可以写以..  也可以是绝对路径

    (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'C:UsersBaiPycharmProjectsuntitled博客') #r表示后面是路径,“”不转义  
    res=os.walk(r'C:UsersBaiPycharmProjectsuntitled博客')
    for cur_path,dirs,files in res: #它有3个参数,分别代表当前目录、当前文件夹、当前文件
        print('当前目录',cur_path)
        print('当前文件夹',dirs)
        print('当前文件',files)
        print('='*50)  #打印50个‘=’

     

     (8)几种获取时间的方法

    • 最近一次的访问时间使用os.path.getatime()方法
    print(os.path.getatime('product.json'))
    • 获取文件的创建时间,使用os.path.getctime()方法
    print(os.path.getctime('product.json'))
    • 获取文件的修改时间,使用os.path.getmtime()方法
    print(os.path.getmtime('product.json'))

    二、小练习

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

    res = os.walk(r'C:UsersBaiPycharmProjectsuntitled博客')
    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'C:UsersBaiPycharmProjectsuntitled博客')
    count = 0
    for cur_path, dirs, files in res:
        print('当前目录下面的所有文件', files)
        print('='*50)
        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  Mac下查找ifconfig
     os.system('dir') #windows下查找当前路径 #在哪个操作系统下,.system里的变量就用哪个操作系统里的命令

    (2)使用.popen()方法

    res=os.popen('ipconfig').read()  #windows下获取ip地址,没有乱码, .read()打印出来,可以拿到返回结果
    print('res结果:',res)

     (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下

    * 该方法的优点是可以跨平台使用这个命令,不会因 系统与系统间的路径分隔符不一样,而报错,我们使用os.path.join时,不需要写分隔符,它会根据相应的系统来帮我们加入该系统的分隔符。

    (3)分割路径

       •   使用.os.path.split()方法,用于分割路径和文件(夹)名

    res=os.path.split(r'C:UsersBaiPycharmProjectsuntitled博客')
    print(res)
    
    #结果('C:\Users\Bai\PycharmProjects\untitled', '博客')
    #会把最后一个【‘博客’】分割出来

    (4)取父目录

       •   使用os.path.dirname()方法

    res=os.path.dirname(r'chinaeijinghaidianchangpinga.py')
    print(res)
    #结果为:chinaeijinghaidianchangping
    #取的是【a.py之前的路径】

    (5)取文件大小

       •   使用os.path.getsize()方法,可以用该方法判断文件是否为空

    * 在当前目录下,可以直接写文件名,如不是在当前文件下,需要写绝对路径

    print(os.path.getsize('笔记.txt'))
    #结果为:839

    (6)取当前的目录

       •   使用os.getcwd()方法

    print(os.getcwd())
    
    #结果:C:UsersBaiPycharmProjectsuntitled摩羯座day5

    (7)根据相对路径取绝对路径

    • 使用os.path.abspath()方法

    print(os.path.abspath('product.json')) 
    #路径里面输入一个点 . 代表当前目录,两个点 . 代表上一级目录
    #括号里面输入(__file__)获取到当前Python文件的绝对路径

    (8)进入到某一个路径下

       •   使用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

  • 相关阅读:
    strcpy 和 strnpy 区别
    js apply/call/caller/callee/bind使用方法与区别分析
    js中的this关键字详解
    Asp.Net_Get跟Post
    Asp.Net_Form验证跟授权
    Css_button样式对不齐
    Asp.Net_上传文件(ftp、webClient、webService)
    Asp.Net_优化
    Asp.Net_后台代码访问前台html标签
    Asp.Net_Ajax调用WebService返回Json前台获取循环解析
  • 原文地址:https://www.cnblogs.com/brf-test/p/11708521.html
Copyright © 2020-2023  润新知