RPA学习:
python遍历文件夹
遍历文件
os.walk用来遍历文件夹:
语法
walk()方法语法格式如下:
os.walk(top[, topdown=True[, οnerrοr=None[, followlinks=False]]])
参数
top – 根目录下的每一个文件夹(包含它自己), 产生3-元组 (dirpath, dirnames, filenames)【文件夹路径, 文件夹名字, 文件名】。
topdown --可选,为True或者没有指定, 一个目录的的3-元组将比它的任何子文件夹的3-元组先产生 (目录自上而下)。如果topdown为 False, 一个目录的3-元组将比它的任何子文件夹的3-元组后产生 (目录自下而上)。
onerror – 可选,是一个函数; 它调用时有一个参数, 一个OSError实例。报告这错误后,继续walk,或者抛出exception终止walk。
followlinks – 设置为 true,则通过软链接访问目录。
返回值
返回生成器。
例如:在访问文件夹获取其中的内容,以及文件的命名和后缀格式:
#首先导入os模块
import os
#str 要访问的路径
str = r'C:\Users\15456\Desktop'
for 文件夹根路径, 子文件夹列表, 文件列表 in os.walk(str):
for i in 文件列表:
print(i)
#其实也可以写成一个参数 这个参数就为一个列表包含以上三种
#但是不能写两个参数,语法不支持会报错
for x in os.walk(str):
for i in x:
print(i)
得到其中的文件整个命名(包含后缀格式):
通过切片进行分开:
#1.通过endwith()函数找到最右边的点进行切割
#2. 通过rfind()函数找到最右边的点
import os
#str 要访问的路径
str = r'C:\Users\15456\Desktop\01-代码-笔记'
x = []
for 文件夹根路径, 子文件夹列表, 文件列表 in os.walk(str):
for 文件名 in 文件列表:
点的位置 = 文件名.rfind('.')
if 文件名[点的位置:] == '.sb3':
x.append(文件名)
print('scratch文件有',x)