一、os.walk()
模块os中的walk()函数可以遍历文件夹下所有的文件。
- os.walk(top, topdown=Ture, onerror=None, followlinks=False)
-
该函数可以得到一个三元tupple(dirpath, dirnames, filenames).
参数含义:
注意,dirnames和filenames均不包含路径信息,如需完整路径,可使用os.path.join(dirpath, dirnames)
下面给出代码:
- # -*- coding: utf-8 -*-
- import os
- def file_name(file_dir):
- for root, dirs, files in os.walk(file_dir):
- print(root) #当前目录路径
- print(dirs) #当前路径下所有子目录
- print(files) #当前路径下所有非目录子文件
如果获取目录中当前的文件夹名字:
- for root, dirs, files in os.walk("D:\develop\张三"):
- print(root.split("\\")[-1]) # 结果张三
当需要特定类型的文件时,代码如下:
- # -*- coding: utf-8 -*-
- import os
-
- def file_name(file_dir):
- L=[]
- for root, dirs, files in os.walk(file_dir):
- for file in files:
- if os.path.splitext(file)[1] == '.jpeg':
- L.append(os.path.join(root, file))
- return L
其中os.path.splitext()函数将路径拆分为文件名+扩展名,例如os.path.splitext(“E:/lena.jpg”)将得到”E:/lena“+".jpg"。
二、os.listdir()
os.listdir()函数得到的是仅当前路径下的文件名,不包括子目录中的文件,所有需要使用递归的方法得到全部文件名。
直接给出代码,函数将返回类型为‘.jpeg'个文件名:
- # -*- coding: utf-8 -*-
- import os
-
- def listdir(path, list_name):
- for file in os.listdir(path):
- file_path = os.path.join(path, file)
- if os.path.isdir(file_path):
- listdir(file_path, list_name)
- elif os.path.splitext(file_path)[1]=='.jpeg':
- list_name.append(file_path)
- # 获取logos文件夹下所有图片的名字,并竖着写入表格
-
- import os
- from openpyxl import Workbook
-
- file_name = os.listdir("./logos")
- item_list =[]
- wb = Workbook()
- ws = wb.active
- # 表头
- ws.append(['图片名字'])
-
- for item in file_name:
- if item[-4:].lower() == '.jpg' or item[-4:].lower() == '.png' or item[-5:].lower() == '.jpeg'or item[-4:].lower() == '.gif':
- item_list.append(item)
- ws.append([item])
- print(item_list)
- wb.save('产品名称.xlsx')
-