一、python中walk()方法遍历目录基本使用
1、walk()方法的基本语法
os.walk(top[, topdown=True[, οnerrοr=None[, followlinks=False]]])
top -- 是你所要遍历的目录的地址.
topdown -- 可选,为 True,则优先遍历top目录,否则优先遍历 top 的子目录(默认为开启)。
onerror -- 可选,需要一个 callable 对象,当 walk 需要异常时,会调用。
followlinks -- 可选,如果为 True,则会遍历目录下的快捷方式,默认开启
return None-- 该函数没有返回值会使用yield关键字抛出一个存放当前该层目录(root,dirs,files)的三元组,最终将所有目录层的的结果变为一个生成器
root 所指的是当前正在遍历的这个文件夹的本身的地址
dirs 是一个 list ,内容是该文件夹中所有的目录的名字(不包括子目录)
files 同样是 list , 内容是该文件夹中所有的文件(不包括子目录)
2、基本使用举例
2.1walk()基本使用,输出基础遍历的各个结果及形式。
#!/usr/bin/ python#walk()基本使用,输出基础遍历的各个结果及形式。
importos
filedir= "/home/dsh/walk_test/"
defwalk_1():
filedir= "/home/dsh/walk_test/"
for root,dirs,files inos.walk(filedir):print(root)print(dirs)print(files)print('***************************')#os.system('pause')
walk_1()
2.2.walk()基本使用,循环输出各级目录名称。
#!/usr/bin/ python#walk()基本使用,循环输出各级目录名称。
importosdefwalk_test():
filedir= "/home/dsh/wall_test/"
for root,dirs,files inos.walk(filedir):for dirs_list indirs:print(dirs_list)print('************')#print("###############")
walk_test()
2.3walk()基本使用,循环输出各级目录下的文件名称
#!/usr/bin/ python#walk()基本使用,输出各级目录下的文件的名称。
importosdefwalk_test():
filedir= "/home/dsh/wall_test/"
for root,dirs,files inos.walk(filedir):for files_list infiles:print(files_list)print("##########")
walk_test()
2.4 walk()基本使用,循环输出各级目录,及目录下的文件名称(带有全路径)
#!/usr/bin/ python#walk()基本使用,输出各级目录,及目录下的文件的名称(带有路径)。
importosimportshutildefwalk_test():
filedir= "/home/dsh/wall_test/"
for root,dirs,files inos.walk(filedir):for dir_list indirs:print(os.path.join(root,dir_list))for files_list infiles:print(os.path.join(root,files_list))print("##########")
walk_test()
二、应用案例1
1、案例场景
需求:复制 指定分机号码目录到 指定文件夹
如下图,分机号码语音文件目录存储结构如下:
2、需要知识点(python读取excel数据,存入list)
根据需求,需要把指定的分机号码数据,存入的list中,以便用来比对是否是目标数据
#-*- coding:utf-8 -*-#读取excel数据,存入list。
importxlrd
path_file= "/home/dsh/wall_test/src/123.xlsx"
defread_excel_to_list(path_to_file):
my_list=[]
file_name= path_to_file #关联带读取的excel文件,最好使用全路径
book_read = xlrd.open_workbook(file_name) #打开文件,创建book对象
sheet1_read = book_read.sheet_by_index(0) #使用book对象,获取工作簿对象
nrows_read = sheet1_read.nrows #获取sheet1工作簿的总行数
#ncols_read = sheet1_read.ncols #获取sheet1工作薄中的总列数
#print (nrows_read)
for i inrange(nrows_read):
cell_value=sheet1_read.cell_value(i,0)
cell_str= str(cell_value).split('.')[0]#print(cell_str,end='\n')
my_list.append(cell_str)returnmy_list
my_List=read_excel_to_list(path_file)if "57939176" inmy_List:print("ok")else:print('false')#print(my_List)
3、案例需求实现代码
#案例需求:把voice目录及其下各个子目录的 指定目录(号码)下的文件,拷贝到其他指定目录。#
importosimportshutilimportxlrd
path_file= "/home/dsh/wall_test/src/123.xlsx"path_source= "/var/spool/voice/voice/"
#path_source = "/home/dsh/walk_test/"
path_dest = "/var/spool/voice/2018/"
defread_excel_to_list(path_to_file):
my_list=[]
file_name= path_to_file #关联带读取的excel文件,最好使用全路径
book_read = xlrd.open_workbook(file_name) #打开文件,创建book对象
sheet1_read = book_read.sheet_by_index(0) #使用book对象,获取工作簿对象
nrows_read = sheet1_read.nrows #获取sheet1工作簿的总行数
#ncols_read = sheet1_read.ncols #获取sheet1工作薄中的总列数
#print (nrows_read)
for i inrange(nrows_read):
cell_value=sheet1_read.cell_value(i,0)
cell_str= str(cell_value).split('.')[0]#print(cell_str,end='\n')
my_list.append(cell_str)returnmy_list
my_List=read_excel_to_list(path_file)for root,dirs,files in os.walk(path_source): #关联待遍历的指定目录
for dir_list in dirs: #遍历目录集合
if dir_list inmy_List:
os.system("mkdir -p"+path_dest+dir_list)
source_Dir= os.path.join(root,dir_list) #生成目标目录的全路径
#shutil.copytree(source_Dir,path_dest+dir_list) #使用shutil.copytree方法复制整个目录
os.system("cp"+source_Dir+"/*"+path_dest+dir_list) #使用os.system方法执行shell命令
#print(source_Dir)
else:continue
print("job is done")
三、应用案例2
需求描述:遍历指定目录,把其及其子目录下所有文件,移动到指定文件内。
代码实现:
#案例需求:把2019目录及其下各个子目录下的所有文件(仅文件),拷贝到指定目录2018中。#
importosimportshutilimportxlrd
path_file= "/home/dsh/wall_test/src/123.xlsx"path_source= "/var/spool/voice/2019/"
#path_source = "/home/dsh/walk_test/"
path_dest = "/var/spool/voice/2018/"
'''def read_excel_to_list(path_to_file):
my_list = []
file_name = path_to_file #关联带读取的excel文件,最好使用全路径
book_read = xlrd.open_workbook(file_name) #打开文件,创建book对象
sheet1_read = book_read.sheet_by_index(0) #使用book对象,获取工作簿对象
nrows_read = sheet1_read.nrows #获取sheet1工作簿的总行数
#ncols_read = sheet1_read.ncols #获取sheet1工作薄中的总列数
#print (nrows_read)
for i in range(nrows_read):
cell_value = sheet1_read.cell_value(i,0)
cell_str = str(cell_value).split('.')[0]
#print(cell_str,end='\n')
my_list.append(cell_str)
return my_list
my_List = read_excel_to_list(path_file)'''
for root,dirs,files in os.walk(path_source): #关联待遍历的指定目录
for file_list in files: #遍历文件集合
#os.system("mkdir -p "+path_dest+dir_list)
source_filedir = os.path.join(root,file_list) #生成目标文件的全路径
shutil.move(source_filedir,path_dest) #使用shutil.move方法移动文件到指定目录
#os.system("cp "+source_Dir+"/* "+path_dest) #使用os.system方法执行shell命令
#print(source_Dir)
print("job is done")