python多线程读取文件夹下的文件_linux 下python多线程递归复制文件夹及文件夹中的文件...

本文是利用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多线程递归复制文件夹及文件夹中的文件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

本文标题: linux 下python多线程递归复制文件夹及文件夹中的文件

本文地址: http://www.cppcns.com/jiaoben/python/296738.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值