Python 官方文档:入门教程 => 点击学习
这篇“怎么在python中用os模块实现批量移动文件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么在Python中用os
这篇“怎么在python中用os模块实现批量移动文件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么在Python中用os模块实现批量移动文件”文章吧。
通过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 += 1if __name__ == '__main__': run_main("D:/source/", "D:/target/")
关于如何复制文件,还可以借助shutil
将文件内容拷贝到另一个文件中
import shutilshutil.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 shutilshutil.copytree('folder1','folder2', ignore=shutil.ignore_patterns('*.pyc','tmp*'))#目标目录不能存在,注意对folder2目录父级目录要有可写权限,ignore的意思是排除shutil.rmtree(path[, ignore_errors[, onerror]])
递归的去删除文件
import shutilshutil.rmtree('folder1')shutil.move(src, dst)
递归的去移动文件,它类似mv命令,其实就是重命名。
import shutilshutil.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 shutilret = shutil.make_archive("data_bak", 'gztar', root_dir='/data')#将 /data下的文件打包放置 /tmp/目录import shutilret = shutil.make_archive("/tmp/data_bak", 'gztar', root_dir='/data')
以上就是关于“怎么在python中用os模块实现批量移动文件”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网Python频道。
--结束END--
本文标题: 怎么在python中用os模块实现批量移动文件
本文链接: https://lsjlt.com/news/329780.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0