我有一个包含许多子目录的大目录,我正在尝试对这些子目录进行排序,我正在尝试将特定的文件类型复制到一个新文件夹中,但我希望保留原始子目录
def copyFile(src, dest):
try:
shutil.copy(src,dest)
except shutil.Error as e:
print('Error: %s' % e)
except IOError as e:
print('Error: %s' % s.strerror)
for root, directories, files in os.walk(directory):
for directoryname in directories:
dirpath = os.path.join(root,directoryname)
dir_paths.append(dirpath)
dir_names.append(directoryname)
if not os.listdir(dirpath): #Cheching if directory is empty
print("Empty")
EmptyDirs.append(directoryname) #Add directory name to empty directory list
EmptyDirPath.append(dirpath)
else:
pass
for filename in files:
filepath = os.path.join(root,filename)
file_paths.append(filepath)
file_names.append(filename)
if filename.lower().endswith(".sldasm"):
print(filename.encode('utf8'))
SolidModels.append(filename)
copyFile(filepath,dest)
elif filename.lower().endswith(".sldprt"):
print(filename.encode('utf8'))
SolidModels.append(filename)
copyFile(filepath,dest)
else:
pass
这是我现在使用的代码,但它只是复制文件,而没有复制它们原来所在的子目录,因此它们在新文件夹中完全没有组织
这是使用copytree的新代码,但是现在特定的文件不会复制,只有子目录会复制
def copytree(src, dst, symlinks=False, ignore=None):
names = os.listdir(src)
if ignore is not None:
ignored_names = ignore(src, names)
else:
ignored_names = set()
os.makedirs(dst)
errors = []
for name in names:
if name in ignored_names:
continue
srcname = os.path.join(src, name)
dstname = os.path.join(dst, name)
try:
if symlinks and os.path.islink(srcname):
linkto = os.readlink(srcname)
os.symlink(linkto, dstname)
elif os.path.isdir(srcname):
copytree(srcname, dstname, symlinks, ignore)
else:
if src is "*.sldasm":
copy2(srcname, dstname)
elif src is "*.sldprt":
copy2(srcname, dstname)
except (IOError, os.error) as why:
errors.append((srcname, dstname, str(why)))
通过使用(滥用?)其可选的} 函数执行您想要的操作。棘手的部分是,如果给定,它必须是一个callable,返回每个目录中应该复制的内容,而不是应该复制的内容
ignore
关键字参数,可以对内置的^{但是,可以编写一个类似于^{} 的工厂函数来创建执行所需操作的函数,并将其用作
ignore
关键字参数的值返回的函数首先通过^{} 函数确定要保留哪些文件,然后将它们从给定目录中的所有文件列表中删除,,除非它们是子目录名,在这种情况下,它们会保留下来供以后[递归]处理。(这就是它复制整个树的原因,也是您尝试编写自己的
copytree()
函数的原因)相关问题 更多 >
编程相关推荐