VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > Python基础教程 >
  • 如何在python中用os模块实现批量移动文件

在工作中难免会遇到需要批量整理文件的情况,当需要从一堆文件中将部分文件批量地转移时,如果手工一一转移难免浪费时间,这篇文章主要给大家介绍了关于如何在python中用os模块实现批量移动文件的相关资料,需要的朋友可以参考下

本文介绍一下利用python批量把一个文件夹(及其子文件夹)下面的特定类型的文件移动到另一个文件夹下

通过python操作系统目录及其文件,需要用到os包,本次具体用到如下方法

os.walk(), 这个方法可以遍历一个文件夹及其子文件(子子文件夹等)
os.rename(),这个方法用于命名文件或目录(因为是操作一个文件的绝对路径,所以其实相当于对文件进行剪切操作)
另外也可以借助 shutil库对文件进行移动或复制操作

下面是示例代码

def run_main(source_dir, target_dir):
    num = 0
    for root, dirs, files in os.walk(source_dir, topdown=False):
        # root 表示当前正在访问的文件夹路径
        # dirs 表示该文件夹下的子目录名list
        # files 表示该文件夹下的文件list
        for name in files:
            # print(os.path.join(root, name))
            # print(type(os.path.join(root, name)))
            file = os.path.join(root, name)  # 拼接文件的完整路径(注意我们对一个文件或文件夹操作,一定要使用绝对路径)
            print(file)
            if file.split(".")[-1] in ["xls", "xlsx", "csv"]:  # 使用split判断获得的文件路径是不是以csv结尾
                # print(file)
                tar_file = file.split(".")[-2]+str(num)+"."+file.split(".")[-1] # 为了避免有重名文件,给原文件名后加一个递增序号num形成新的文件名
                # print(target_dir+tar_file.split("\\")[-1])
                if os.path.isfile(target_dir + tar_file.split("\\")[-1]): # 判断目标文件夹是否已存在该文件
                    print("已经存在该文件")
                else:
                    print("正在移动第{}个文件:{}".format(num+1, tar_file.split("\\")[-1]))
                    os.rename(file, target_dir + tar_file.split("\\")[-1])
                num += 1
if __name__ == '__main__':
    run_main("D:/source/", "D:/target/")

关于如何复制文件,还可以借助shutil

将文件内容拷贝到另一个文件中

import shutil
shutil.copyfileobj(open('old.xml','r'), open('new.xml','w'))
shutil.copyfile(src, dst)

拷贝文件

shutil.copyfile('f1.log','f2.log')#目标文件无需存在
shutil.copymode(src, dst)

仅拷贝权限。内容、组、用户均不变

shutil.copymode('f1.log','f2.log')#目标文件必须存在
shutil.copystat(src, dst)

仅拷贝状态的信息,包括:mode bits, atime, mtime, flags

shutil.copystat('f1.log','f2.log')#目标文件必须存在
shutil.copy(src, dst)

拷贝文件和权限

import shutil23shutil.copy('f1.log','f2.log')
shutil.copy2(src, dst)

拷贝文件和状态信息

import shutil23shutil.copy2('f1.log','f2.log')
shutil.ignore_patterns(*patterns) #基本用不到
shutil.copytree(src, dst, symlinks=False, ignore=None)

递归的去拷贝文件夹

import shutil
shutil.copytree('folder1','folder2', ignore=shutil.ignore_patterns('*.pyc','tmp*'))
#目标目录不能存在,注意对folder2目录父级目录要有可写权限,ignore的意思是排除
shutil.rmtree(path[, ignore_errors[, onerror]]) 

递归的去删除文件

import shutil
shutil.rmtree('folder1')
shutil.move(src, dst)

递归的去移动文件,它类似mv命令,其实就是重命名。

import shutil
shutil.move('folder1','folder3')
shutil.make_archive(base_name, format,...)

创建压缩包并返回文件路径,例如:zip、tar

base_name: 压缩包的文件名,也可以是压缩包的路径。只是文件名时,则保存至当前目录,否则保存至指定路径,

如:/tmp/data_bak =>保存至/tmp/

format: 压缩包种类,“zip”, “tar”, “bztar”,“gztar”

root_dir: 要压缩的文件夹路径(默认当前目录)

owner: 用户,默认当前用户

group: 组,默认当前组

logger: 用于记录日志,通常是logging.Logger对象

#将 /data 下的文件打包放置当前程序目录
import shutil
ret = shutil.make_archive("data_bak", 'gztar', root_dir='/data')
#将 /data下的文件打包放置 /tmp/目录
import shutil
ret = shutil.make_archive("/tmp/data_bak", 'gztar', root_dir='/data')

总结

到此这篇关于如何在python中用os模块实现批量移动文件的文章就介绍到这了,更多相关python用os模块批量移动文件内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

原文链接:https://blog.csdn.net/qdPython/article/details/124866958


相关教程