怎么新建MySQL数据库

发布时间:2022-08-25 作者:admin
阅读:352
今天这篇给大家分享的知识是“python中有什么方法实现批量移动文件夹”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“python中有什么方法实现批量移动文件夹”文章能帮助大家解决问题。

本文介绍一下利用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中有什么方法实现批量移动文件夹”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注群英网络,小编每天都会为大家更新不同的知识。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

二维码-群英

长按识别二维码并关注微信

更方便到期提醒、手机管理

7*24 全天候服务

售前 400-678-4567

售后 0668-2555666

售后 400 678 4567

信息安全 0668-2555 118

域名空间 3004329145