将路径过长的文件复制到 Python 中的另一个目录

2023-08-31Python开发问题
12

本文介绍了将路径过长的文件复制到 Python 中的另一个目录的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我正在尝试使用 Python 2.7 在 Windows 上复制文件,但有时会失败.

I am trying to copy files on Windows with Python 2.7, but sometimes this fails.

shutil.copyfile(copy_file, dest_file)

我收到以下 IOError:

I get the following IOError:

[Errno 2] No such file or directory

但是文件确实存在!问题是文件的路径太长.(> 255 个字符)

But the file does exist! The problem is that the path of the file is too long. (> 255 characters)

如何复制这些文件?在其他应用程序中打开它们不是问题.

How do I copy these files? It isn't a problem to open them in other applications.

要创建路径过长的文件,请创建一个文件名尽可能长的文件,并将包含的文件夹移到树结构的更深处.

To create a file with a too long path, create a file with an as long as possible file name and move the containing folder deeper down a tree structure.

我一直在尝试其中一些方法但没有成功:http://timgolden.me.uk/python/win32_how_do_i/copy-a-file.html

I've been trying some of these methods without success: http://timgolden.me.uk/python/win32_how_do_i/copy-a-file.html

推荐答案

我不确定 255 字符的限制,所以我偶然发现了 这篇文章.在那里我找到了一个可行的答案:在路径之前添加 \?.

I wasn't sure about the 255 char limit so I stumbled on this post. There I found a working answer: adding \? before the path.

shutil.copyfile("\\?\" + copy_file, dest_file)

我发现使用长路径会导致 Windows 出现问题.我使用的另一个技巧是缩短路径:

edit: I've found that working with long paths causes issues on Windows. Another trick I use is to just shorten the paths:

import win32api
path = win32api.GetShortPathName(path)

这篇关于将路径过长的文件复制到 Python 中的另一个目录的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

在xarray中按单个维度的多个坐标分组
groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)...
2024-08-22 Python开发问题
15

Pandas中的GROUP BY AND SUM不丢失列
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)...
2024-08-22 Python开发问题
17

pandas 有从特定日期开始的按月分组的方式吗?
Is there a way of group by month in Pandas starting at specific day number?( pandas 有从特定日期开始的按月分组的方式吗?)...
2024-08-22 Python开发问题
10

GROUP BY+新列+基于条件的前一行抓取值
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)...
2024-08-22 Python开发问题
18

PANDA中的Groupby算法和插值算法
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)...
2024-08-22 Python开发问题
11

PANAS-基于列对行进行分组,并将NaN替换为非空值
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)...
2024-08-22 Python开发问题
10