zoukankan      html  css  js  c++  java
  • Python os模块实例之遍历目录及子目录指定扩展名的文件

    需求:在该目录下有很多子目录(如下图,截图了部分),现要从该目录和所有子目录下找到所有扩展名为.meta的文件,并获取文件中第二行guid的值(': '后面的),然后将所有guid的值输出到另一文件中

    .meta文件截图:

    思路:

    遍历当前目录的子目录,如果是文件并且扩展名为.meta,获取guid,写入到guid.txt;如果是子目录,则遍历子目录下的文件。

     方法一:

    #!usr/bin/env python
    # -*- coding: utf-8 -*-
    
    import os
    
    outfile = open('guid.txt', 'a')                         # 以追加方式打开输出文件
    for dir in os.listdir('.'):                             # 遍历当前目录所有问价和目录
        child = os.path.join('.', dir)                      # 加上路径,否则找不到
        if os.path.isdir(child):                            # 如果是目录,则继续遍历子目录的文件
            for file in os.listdir(child):                    
                if os.path.splitext(file)[1] == '.meta':    # 分割文件名和文件扩展名,并且扩展名为'meta'        
                    file = os.path.join(child, file)        # 同样要加上路径
                    f = open(file, 'r')
                    guid = f.readlines()[1].split(': ')[1]  # 获取文件第二行以': '分割的后者
                    outfile.write(guid)                     # 写入输出文件
                    f.close()                        
        elif os.path.isfile(child):                         # 如果是文件,则直接判断扩展名
            if os.path.splitext(child)[1] == '.meta':
                f = open(child, 'r')
                guid = f.readlines()[1].split(': ')[1]
                outfile.write(guid)
                f.close()
    outfile.close()

    方法二:上面的方法只能遍历两级目录,如果要遍历三级目录,必须还要加一个for循环。那么可以用到os.walk()方法一次性遍历当前目录和所有子目录的文件和目录。

    #!usr/bin/env python
    # -*- coding: utf-8 -*-
    
    import os
    
    outfile = open('guid.txt', 'a')                          # 以追加方式打开输出文件
    for dirpath, dirs, files in os.walk('.'):                # 递归遍历当前目录和所有子目录的文件和目录
        for name in files:                                   # files保存的是所有的文件名
            if os.path.splitext(name)[1] == '.meta':        
                filename = os.path.join(dirpath, name)       # 加上路径,dirpath是遍历时文件对应的路径
                f = open(filename, 'r')
                guid = f.readlines()[1].split(': ')[1]       # 获取文件第二行以': '分割的后者
                outfile.write(guid)                          # 写入输出文件
                f.close()    
    outfile.close()

    在该目录下运行此程序,将会得到guid.txt。

    相关方法的作用和理解见:http://www.cnblogs.com/victorwu/p/5838430.html

  • 相关阅读:
    期末总结
    作业01 第一次作业 入门
    C语言I博客作业09
    C语言I博客作业08
    C语言I博客作业07
    C语言I博客作业06
    C语言|博客作业05
    通过Excel批量导入数据-Java代码
    python3-easygui模块安装
    com.alibaba.fastjson.JSONArray cannot be cast to XX
  • 原文地址:https://www.cnblogs.com/victorwu/p/5840099.html
Copyright © 2011-2022 走看看