本文跟大家分享一个文件整理脚本的实现过程。具体的功能很简单,给定一个打算整理的文件夹目录,这个脚本可以将该目录下的所有文件都揪出来,并且根据后缀名归类到不同的文件夹里,就像下图一样,简直是整理爱好者的福音
通过本例还可以学到:os
、glob
、shutil
三个标准库的综合运用,现在让我们一起来捋一捋实现的逻辑。
首先是导入需要的库
import os
import shutil
import glob
os
库可以完成操作系统层面大量操作,例如文件夹的创建、移动、重命名、删除等,有些功能实现的不是很完美,就用到shutil
库跟其互补了,例如文件的复制、移动等。glob
库可以利用通配符进行文件的搜索获取,非常强大
# 设置建立分类总文件夹的路径,这里按自己的实际路径修改
mkdir_path = r'C:\Users\chenx\文件夹分类'
# 设置需要遍历整理的文件夹路径,可以依据自己的实际需求修改
goal_dir = r'C:\xxxxxxxx)'
if not os.path.exists(mkdir_path):
os.mkdir(mkdir_path)
os.mkdir
可以在指定路径创建文件夹,但如果文件夹已经存在则会报错,因此谨慎一点可以利用os.path.exists
先对文件夹的存在与否进行判断,接下来是代码核心循环,为了方便理解先简化成如下形式:
for file in glob.glob(f'{goal_dir}/**/*', recursive=True):
if os.path.isfile(file):
print(file)
glob.glob(f'{goal_dir}/**/*', recursive=True)
中**/*
是通配符的重要用法,*
可以代表任意个字符,包括0个字符,recursive
参数的设置确保遍历。由于需要找出所有的文件而非文件夹,这里用os.path.isfile
进行判断。最后可以输出文件的绝对路径先看看代码有没出现错误,让我们继续往下写
for file in glob.glob(f'{goal_dir}/**/*', recursive=True):
if os.path.isfile(file):
filename = os.path.basename(file)
if '.' in filename:
suffix = filename.split('.')[-1]
else:
特别提醒:
1、请用户自行保存原始数据,为确保安全网站使用完即被永久销毁,如何人将无法再次获取。
2、如果上次文件较大或者涉及到复杂运算的数据,可能需要一定的时间,请耐心等待一会。
3、请按照用户协议文明上网,如果发现用户存在恶意行为,包括但不限于发布不合适言论、妄图
获取用户隐私信息等行为,网站将根据掌握的情况对用户进行限制部分行为、永久封号等处罚。
4、如果文件下载失败可能是弹出窗口被浏览器拦截,点击允许弹出即可,一般在网址栏位置设置
5、欢迎将网站推荐给其他人,网站持续更新更多功能敬请期待,收藏网站高效办公不迷路。