本文是利用python 复制文件夹 刚开始写了一个普通的递归复制文件夹 然后想了想 觉得对io频繁的程序 threading 线程还比较友好 就写了个多线程版本的 最恶心人的地方就是路径 其他都还好吧
import os import threading import multiprocessing length_of_folder = 0 def copyfile(Path): if os.path.isdir(Path): print("-----------%s" % ("Testfortherading_" + '/' + Path[length_of_folder:])) os.makedirs("Testforthreading_" + '/' + Path[length_of_folder:]) filenames = os.listdir(Path) for filename in filenames: if os.path.isdir(Path + '/' + filename): #ps = "Testforthreading_" +"/" + Path[length_of_folder:] #print("%s" % (ps + '/' + filename)) #os.mkdir(ps + '/' + filename) temp = Path + '/' + filename t = threading.Thread(target=copyfile , args=(temp,)) t.start() else: f = open(Path + '/' + filename , 'rb') content = f.read() F = open('Testforthreading_' + '/' + Path[length_of_folder:]+ '/' + filename , 'wb') F.write(content) f.close() F.close() def main(): """""" foldername = input("Please input the folder you want to copy:") length_of_folder = len(foldername) if os.path.isdir("Testforthreading_"): os.removedirs("Testforthreading_") os.mkdir("Testforthreading_") copyfile(foldername) #p = multiprocessing.Pool(10) #que = multiprocessing.Manager().Queue() if __name__ == "__main__": main()
ps:Python多进程递归复制文件夹中的文件
import multiprocessing import os import reimport time # 源文件夹地址、目标文件夹地址 SOUR_PATH = "" DEST_PATH = "" # 源文件列表 文件夹列表 SOUR_FILE_LIST = list() SOUR_DIR_LIST = list() def traverse(source_path): """递归遍历源文件夹,获取文件夹列表、文件列表 :param source_path: 用户指定的源路径 """ if os.path.isdir(source_path): SOUR_DIR_LIST.append(source_path) for temp in os.listdir(source_path): new_source_path = os.path.join(source_path, temp) traverse(new_source_path) else: SOUR_FILE_LIST.append(source_path) def copy_files(queue, sour_file, dest_file): """复制文件列表中的文件到指定文件夹 :param queue: 队列,用于监测进度 :param sour_file: :param dest_file: """ # time.sleep(0.1) try: old_f = open(sour_file, "rb") new_f = open(dest_file, "wb") except Exception as ret: print(ret) else: content = old_f.read() new_f.write(content) old_f.close() new_f.close() queue.put(sour_file) def main(): source_path = input("请输入需要复制的文件夹的路径:\n") SOUR_PATH = source_path DEST_PATH = SOUR_PATH + "[副本]" # dest_path = input("请输入目标文件夹路径") # DEST_PATH = dest_path print(">>>源文件夹路径:", SOUR_PATH) print(">目标文件夹路径:", DEST_PATH) print("开始计算文件...") queue = multiprocessing.Manager().Queue() po = multiprocessing.Pool(5) traverse(source_path) print("创建目标文件夹...") for sour_dir in SOUR_DIR_LIST: dest_dir = sour_dir.replace(SOUR_PATH, DEST_PATH) try: os.mkdir(dest_dir) except Exception as ret: print(ret) else: print("\r目标文件夹 %s 创建成功" % DEST_PATH, end="") print() print("开始复制文件") for sour_file in SOUR_FILE_LIST: dest_file = sour_file.replace(SOUR_PATH, DEST_PATH) po.apply_async(copy_files, args=(queue, sour_file, dest_file)) count_file = len(SOUR_FILE_LIST) count = 0 while True: q_sour_file = queue.get() if q_sour_file in SOUR_FILE_LIST: count += 1 rate = count * 100 / count_file print("\r文件复制进度: %.2f%% %s" % (rate, q_sour_file), end="") if rate >= 100: break print() ret = re.match(r".*\\([^\\]+)", SOUR_PATH) name = ret.group(1) print("文件夹 %s 复制完成" % name) if __name__ == '__main__': main()
总结
以上所述是小编给大家介绍的linux 下python多线程递归复制文件夹及文件夹中的文件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
本文向大家介绍Java使用递归复制文件夹及文件夹,包括了Java使用递归复制文件夹及文件夹的使用技巧和注意事项,需要的朋友参考一下 递归调用copyDir方法实现,查询源文件目录使用字节输入流写入字节数组,如果目标文件目录没有就创建目录,如果迭代出是文件夹使用字节输出流对拷文件,直至源文件目录没有内容。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
问题内容: 我在删除空目录时遇到问题。这是我的代码: 参数是我要传递需要完成工作的目录的位置。该目录如下所示: 请注意,以上所有文件夹均为空。当我运行该脚本的文件夹,单独被删除!但是,文件夹,并不会被删除,即使它们是空文件夹。 编辑: 我得到的例外是: 我在哪里弄错了? 问题答案: 尝试:
我正在寻找一种方法来获取zip文件中的文件列表。我创建了一个方法来获取目录中的文件列表,但我也在寻找一种方法来获取zip文件中的文件,而不是只显示zip文件。 以下是我的方法:
问题内容: 我想扫描目录树并列出每个目录中的所有文件和文件夹。我创建了一个程序,可从网络摄像机下载图像并将其保存在本地。该程序根据图片的下载时间创建文件树。我现在想扫描这些文件夹并将图像上传到Web服务器,但是我不确定如何扫描目录以查找图像。如果有人可以张贴一些示例代码,那将非常有帮助。 编辑 :我在嵌入式linux系统上运行它,不想使用boost 问题答案: 请参阅以获取简单的“文件树遍历”。我
问题内容: 这个问题已经在这里有了答案 : 使用Java将文件从一个目录复制到另一个目录 (33个答案) 4年前关闭。 如何将一个文件夹及其所有子文件夹和文件复制到另一个文件夹中? 问题答案: Apache Commons IO可以为您解决问题。看看FileUtils。
问题内容: 我在将包含该文件夹中文件的文件夹复制到另一个文件夹时遇到一些问题。Command 不会复制文件夹中的文件。 问题答案: 您正在寻找的选项是。 如果不存在,将创建它。 意味着。您也可以使用,因为它不区分大小写。 请注意根据@ muni764的注释添加尾随的细微差别。