可以使用Python的glob模块来遍历目录,并查找.xls文件。但是默认情况下,glob模块会忽略以点开头的文件(例如隐藏文件)和以~结尾的文件(例如临时文件)。因此,我们可以使用fnmatch模块来进一步过滤文件,以查找.xls文件。以下是一个示例代码:
import glob
import fnmatch
def find_xls_files(directory):
xls_files = []
for file in glob.glob(directory + '/**/*', recursive=True):
if fnmatch.fnmatch(file, '*.xls'):
xls_files.append(file)
return xls_files
# 示例用法
directory = '/path/to/directory' # 替换为实际目录路径
xls_files = find_xls_files(directory)
for file in xls_files:
print(file)
在上面的代码中,find_xls_files
函数接受一个目录路径作为参数,并返回一个包含所有.xls文件路径的列表。它使用glob.glob
函数来遍历目录和子目录中的所有文件。然后,使用fnmatch.fnmatch
函数来检查文件名是否匹配*.xls模式。如果匹配,将文件路径添加到xls_files
列表中。
注意,glob.glob
函数需要设置recursive=True
参数以递归遍历子目录。另外,fnmatch.fnmatch
函数使用通配符模式匹配文件名,其中表示任意字符,?表示单个字符。所以'.xls'表示以.xls结尾的文件名。
最后,我们可以使用示例用法来调用find_xls_files
函数,传递目录路径,并打印所有.xls文件的路径。请记得将directory
变量替换为实际目录路径。
下一篇:遍历MySQL变量