我有一个简单的程序,它查找目录中的所有压缩文件夹,定位一个压缩文件,获取位于压缩文件内的excel文件并将其移动到另一个位置(它为每个excel文件执行此操作,对于有多少压缩文件文件夹):
path = 'C:\Users\me\Documents\Extract'
new_path = 'C:\Users\me\Documents\Test'
i = 0
for folder in os.listdir(path):
path_to_folder = os.path.join(path, folder)
zfile = zipfile.ZipFile(os.path.join(path, folder))
for name in zfile.namelist():
if name.endswith('.xls'):
new_name = str(i)+'_'+name
new_path = os.path.join(new_path, new_name)
zfile.close()
#os.rename(path_to_folde, new_path) -- ERROR HERE
shutil.move(path_to_folde, new_path) -- AND ERROR HERE
i += 1
Run Code Online (Sandbox Code Playgroud)
我试过两种方法来移动excel文件os.rename和shutil.move.我一直在收到错误:
WindowsError:[错误32]由于另一个进程正在使用该进程,该进程无法访问该文件.
我不明白为什么这个错误仍然存在,因为我关闭了每个文件夹.
Ore*_*ail 10
path = 'C:\Users\me\Documents\Extract'
destination_path = 'C:\Users\me\Documents\Test'
i = 0
for folder in os.listdir(path):
path_to_zip_file = os.path.join(path, folder)
zfile = zipfile.ZipFile(path_to_zip_file)
for name in zfile.namelist():
if name.endswith('.xls'):
new_name = str(i)+'_'+name
new_path = os.path.join(destination_path, new_name)
# This is obviously going to fail because we just opened it
shutil.move(path_to_zip_file, new_path)
i += 1
zfile.close()
Run Code Online (Sandbox Code Playgroud)
更改了代码段中的一些变量名称.你现在看到你的问题了吗?你想移动的zip文件的进程打开.您需要.xls使用zipfile模块将文件复制到目标位置.
如果您使用的是 Windows 计算机,请转到任务管理器并点击进程选项卡。向下滚动到任何说 python 的内容并结束该过程。您可能让 python 与其他东西一起运行。然后再次尝试运行您的 python 程序,它应该可以工作。
| 归档时间: |
|
| 查看次数: |
35234 次 |
| 最近记录: |