需求:在该目录下有很多子目录(如下图,截图了部分),现要从该目录和所有子目录下找到所有扩展名为.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