python实现目录文件打印
用tuple进行当前目录下子目录及文件名的获取,代码如下:
# 导入模块
import os
# 生成一个元组
ret_tuple = ()
ret_tuple = os.walk('.\\', topdown=True)
print(ret_tuple)
执行上面代码,我们发现print(ret_tuple)的打印结果为:
<generator object walk at 0x00000238374B6CA8>
我们发现ret_tuple的输出不是一个直接的信息展示,而是一个地址,这是为什么呢?
结果分析
在 Python 中,os.walk() 函数返回的是一个生成器(generator),而不是直接返回包含所有文件和目录结构的元组。生成器是一种迭代器(iterator),它会在迭代时动态地计算出下一个值,而不是事先计算出所有的值占用内存。
生成器通常用于大型集合或无限序列,这样在使用这些数据时可以节省内存,因为生成器只会在每次迭代中产生一个值。
输出中的16进制字符是这个生成器对象在内存中的地址表示。要访问os.walk()返回的路径、目录名和文件名信息,您需要迭代这个生成器对象。
其中os.walk 返回一个三元组的生成器(generator)。
格式为 (dirpath, dirnames, filenames)
迭代输出
# 导入模块
import os
# 生成一个元组
ret_tuple = ()
ret_tuple = os.walk('.\\', topdown=True)
# print(ret_tuple)
print('\\当前目录结构如下所示:')
# 通过生成器迭代输出
for cur_dir, list_dir, list_file in ret_tuple:
# 显示当前目录名
print('当前目录:', cur_dir)
if len(list_dir) > 0:
# 显示当前目录中的子目录
print('包含的子目录:', list_dir)
if len(list_file) > 0:
# 显示当前目录中的文件
print('当前目录下的文件:', list_file)
# 打印分隔符
print('=' * 30)
再次运行即可正确输出。
通过python代码定位特定目录中满足条件的文件
在处理大量数据或管理庞大的文件系统时,手动寻找特定条件的文件不仅耗时而且低效。本文介绍的Python脚本正是为了解决这一问题而生,此脚本能自动遍历指定目录,高效地筛选出匹配筛选条件的文件。
代码如下:
import os
# 定义一个根据关键字查找文件的函数
def search_file(search_path, key_word):
# 如果传入的search_path不是文件夹名,直接退出
if not os.path.isdir(search_path):
print('查找的不是文件夹,退出')
return
# 通过循环取得目录下的文件或子目录
for field_or_dir in os.listdir(search_path):
# 将上级目录与其下的文件或子目录串联起连接起来形成一个路径
path_join = os.path.join(search_path, field_or_dir)
# 判断是否是目录
if os.path.isdir(path_join):
# 如是是目录递归调用本函数
search_file(path_join, key_word)
# 如果是文件,就判断关键字是否包含在文件名中
elif key_word in os.path.basename(path_join):
# 打印出文件名包含关键字的文件的名字
print(os.path.abspath(path_join))
# 主函数main
if __name__ == '__main__':
search_path = input('请录入要查找的目录:')
key_word = input('请录入查找文件的关键字:')
print('文件夹[', search_path, ']中包含[', key_word, ']关键字的文件列举如下:')
# 调用函数查找文件
search_file(search_path, key_word)
我们可以按照提示,依次输入需要寻找的目录和文件关键字来实现,代码运行结果如下:
参考 python编程100例