Я уже читал этот поток, но когда я его внедряю в свой код, он работает только для нескольких итераций.
Я использую python для итерации по каталогу (позволяет вызвать его переместить каталог), чтобы копировать в основном файлы PDF (соответствующие уникальному идентификатору) в другой каталог (базовый каталог) в соответствующую папку (с соответствующим уникальным идентификатором). Я начал использовать shutil.copy
, но если есть дубликаты, он перезаписывает существующий файл.
Я хотел бы иметь возможность искать в соответствующей папке, чтобы увидеть, существует ли файл, и итеративно называть его, если встречается более одного.
например.
- скопировать файл 1234.pdf в папку в базовом каталоге 1234.
- если существует 1234.pdf, чтобы назвать его 1234_1.pdf,
- если другой pdf будет скопирован как 1234.pdf, тогда это будет 1234_2.pdf.
Вот мой код:
import arcpy
import os
import re
import sys
import traceback
import collections
import shutil
movdir = r"C:\Scans"
basedir = r"C:\Links"
try:
#Walk through all files in the directory that contains the files to copy
for root, dirs, files in os.walk(movdir):
for filename in files:
#find the name location and name of files
path = os.path.join(root, filename)
print path
#file name and extension
ARN, extension = os.path.splitext(filename)
print ARN
#Location of the corresponding folder in the new directory
link = os.path.join(basedir,ARN)
# if the folder already exists in new directory
if os.path.exists(link):
#this is the file location in the new directory
file = os.path.join(basedir, ARN, ARN)
linkfn = os.path.join(basedir, ARN, filename)
if os.path.exists(linkfn):
i = 0
#if this file already exists in the folder
print "Path exists already"
while os.path.exists(file + "_" + str(i) + extension):
i+=1
print "Already 2x exists..."
print "Renaming"
shutil.copy(path, file + "_" + str(i) + extension)
else:
shutil.copy(path, link)
print ARN + " " + "Copied"
else:
print ARN + " " + "Not Found"