gpt4 book ai didi

python - 有没有办法在 Python 中中断 shutil copytree 操作?

转载 作者:太空狗 更新时间:2023-10-30 01:24:55 25 4
gpt4 key购买 nike

总的来说,我对编程还很陌生。我需要开发一个程序,它可以一次复制多个目录,并且还要考虑到多个文件类型的异常。我遇到了 shutil 模块,它提供了 copytree 和 ignore_patterns 功能。这是我的代码片段,它也使用了 wxPython 多目录对话框:

import os
import wx
import wx.lib.agw.multidirdialog as MDD
from shutil import copytree
from shutil import ignore_patterns

app = wx.App(0)
dlg = MDD.MultiDirDialog(None, title="Custom MultiDirDialog", defaultPath=os.getcwd(), agwStyle=MDD.DD_MULTIPLE|MDD.DD_DIR_MUST_EXIST)

dest = "Destination Path"

if dlg.ShowModal() != wx.ID_OK:
dlg.Destroy()

paths = dlg.GetPaths()

ext = ['*.tiff', '*.raw', '*.p4p', '*.hkl', '*.xlsx']

for path in enumerate(paths):
directory = path[1].replace('Local Disk (C:)','C:')
copytree(directory, dest, ignore=ignore_patterns(directory, *ext))

dlg.Destroy()
app.MainLoop()

这段代码对我来说效果很好。有时,我会复制数 TB 的数据。无论如何可以中断 shutil.copytree 吗?我问这个,因为我第一次运行这个程序时,我选择了一个相当大的目录并无意中复制了大量文件(成功!)并且想停止它 :( 。一旦我解决了这个问题,我终于开始了在 GUI 上!如果我可以提供更多信息,请告诉我!在此先感谢您提供的所有帮助!

最佳答案

您可以使用 multiprocessing 在单独的 Python 进程中运行副本模块。代码可能看起来像这样:

import time
import shutil
from multiprocessing import Process


def cp(src: str, dest: str):
shutil.copytree(src, dest)


if __name__ == '__main__':
proc = Process(target=cp, args=('Downloads', 'Tmp'), daemon=True)
proc.start()
time.sleep(3)
proc.terminate()

在我的示例中,主进程启动了一个子进程,该子进程执行实际的处理,并在 3 秒后终止它。您还可以通过调用进程的 is_alive() 方法来检查进程是否正在运行。

关于python - 有没有办法在 Python 中中断 shutil copytree 操作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53815576/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com