Python实现自动整理文件的示例代码
一、前言
今天我们就带大家来实现一下文件自动整理的操作。在我们日常生活中,文件总是杂乱无章的,这个时候就需要我们整理一下。但是文件太多的话整理起来是非常麻烦的,因此我们今天就来用Python实现文件的自动整理。
二、遍历文件
要整理文件,我们首先需要遍历文件。这里用两种方法,一种是直接获取指定目录下的所有文件和文件夹。另外一种就是获取指定目录下的文件、文件夹和子文件、文件夹...
我们这里直接看看代码:
import os basedir = "test1" file_list = [os.path.join(basedir, i) for i in os.listdir(basedir)] print(file_list)
输出效果如下:
['test1\\a1.jpeg', 'test1\\a2.jpeg', 'test1\\a3.jpeg']
接下来看第二种:
import os basedir = r"D:\\" for root, dirs, files in os.walk(basedir): for file in files: path = os.path.join(root, file) print(path)
这里我们直接遍历D盘下的文件,输出结果部分如下:
EM.rst.txt
D:\\CodeFile\cmake-3.15.0-rc1-win64-x64\doc\cmake\html\_sources\variable\CMAKE_HOST_SYSTEM_NAME.rst.txt
D:\\CodeFile\cmake-3.15.0-rc1-win64-x64\doc\cmake\html\_sources\variable\CMAKE_HOST_SYSTEM_PROCESSOR.rst.txt
D:\\CodeFile\cmake-3.15.0-rc1-win64-x64\doc\cmake\html\_sources\variable\CMAKE_HOST_SYSTEM_VERSION.rst.txt
这样我们就完成了遍历的操作。
三、移动文件
移动文件的操作非常简单,我们只需要调用os.renames
函数即可,使用如下:
import os os.renames(".\\test\\1.jpg", "1.jpg")
上面的代码效果就是将当前目录下的test目录中的1.jpg图片移动到当前目录下。或者我们可以使用绝对路径:
import os os.renames(r"D:\test1\a2.jpeg", r"D:\a1.jpeg")
这样我们就实现了文件的移动。而我们整理文件的操作就是按照一定规则移动文件。
四、自动整理文件
整理图片的操作是多种多样的,对于不同的人,整理要求也不一样。因此这里只是说一些可能需要的一些整理操作。
1、将图片集中存放
有时候我们可能会把图片集中放置在一个目录下,或者需要把指定名称的图片放在一个目录下(比如QQ图片的命名规则是IMG_...,我们可以通过这点整理所有QQ图片)。这个时候我们就可以用今天的内容来完成了。
import os todir = "D:\imgs" basedir = r"D:\\" # 如果目录不存在,则创建 if not os.path.exists(todir): os.mkdir(todir) img_name = 1000 for root, dirs, files in os.walk(basedir): for file in files: path = os.path.join(root, file) if path.endswith(".jpg"): # 移动文件 os.renames(path, "D:\\imgs\\" + str(img_name) + ".jpg") img_name += 1
这里我们实现了将所有jpg文件整理到指定目录的操作。但是有时候移动文件是一件很危险的事情,因此我们还可以选择不移动文件,而且复制文件:
import os todir = "D:\\imgs" basedir = r"D:\\" # 如果目录不存在,则创建 if not os.path.exists(todir): os.mkdir(todir) img_name = 1000 for root, dirs, files in os.walk(basedir): for file in files: path = os.path.join(root, file) if path.endswith(".jpg"): # 移动文件 with open(path, "rb") as f1: with open("D:\\imgs\\" + str(img_name) + ".jpg", "wb") as f2: content = f1.read() f2.write(content) img_name += 1
这样我们就实现了文件的复制。
2、同步整理文件
我们还可以做一些其它整理工作,只需要在遍历中添加一些条件即可:
import os todir = "D:\\imgs" basedir = r"D:\\" # 如果目录不存在,则创建 if not os.path.exists(todir): os.mkdir(todir) img_name = 1000 for root, dirs, files in os.walk(basedir): for file in files: path = os.path.join(root, file) if path.endswith(".jpg"): # 整理图片 elif path.endswith(".txt"): # 整理文本 else: pass
这样我们就可以按照自己的想法来整理文件。
3、获取文件属性
其它文件整理操作这里就不说了,我们再来说一下获取文件属性的操作。代码如下:
import os stat = os.stat("test1/a3.jpeg") print(stat)
我们通过上面的代码就可以查看文件的属性,输出内容如下:
os.stat_result(st_mode=33206, st_ino=281474977264692, st_dev=275139486, st_nlink=1, st_uid=0, st_gid=0, st_size=95289, st_atime=1632752119, st_mtime=1586520880, st_ctime=1632664508)
这里包括文件模式,文件大小,创建时间修改时间等。这样我们在拿到这些信息后就可以更准确地整理文件了。比如我们可以把最近一天修改的文件整理出来,这样我们就可以找到我们想用的文件了。
到此这篇关于Python实现自动整理文件的示例代码的文章就介绍到这了,更多相关Python自动整理文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
python中[[]] * (n)和[[] for _ in 
本文主要介绍了python中[[]] * (n)和[[] for _ in range(n)]的区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2024-02-02Python标准库之多进程(multiprocessing包)介绍
这篇文章主要介绍了Python标准库之多进程(multiprocessing包)介绍,本文讲解了进程池、共享资源、共享内存、Manager等内容,需要的朋友可以参考下2014-11-11解决python打开https出现certificate verify failed的问题
这篇文章主要介绍了解决python打开https出现certificate verify failed的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-09-09
最新评论