2013-08-22 10 views
11

Ho già letto this thread ma quando lo implemento nel mio codice funziona solo per poche iterazioni.Python copia i file in una nuova directory e rinomina se il nome del file esiste già

Sto usando python per scorrere una directory (chiamiamola spostare directory) per copiare principalmente i file pdf (corrispondenti a un ID univoco) in un'altra directory (directory di base) nella cartella corrispondente (con l'ID univoco corrispondente) . Ho iniziato a utilizzare shutil.copy ma se ci sono duplicati sovrascrive il file esistente.

Mi piacerebbe poter cercare nella cartella corrispondente per vedere se il file esiste già, e chiamarlo iterativamente se ne occorrono più di uno.

ad es.

  • copia del file 1234.pdf nella cartella nella directory di base 1234.
  • se 1234.pdf esiste per nominarlo 1234_1.pdf,
  • se un altro pdf viene copiato come 1234.pdf allora sarebbe 1234_2 .PDF.

Ecco il mio codice:

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" 
+0

No, la struttura è diversa. Ad esempio, movdir è una scansione delle informazioni di proprietà ed è stata organizzata per nome della via e i pdf sono nominati con l'ID univoco. Quindi C: \ Scans \ Main St \ 1234.pdf Il basedir è una nuova struttura che organizzerà tutte le informazioni per una particolare proprietà tramite il suo ID univoco. Quindi C: \ Links \ 1234 e potrebbero esserci ulteriori sottocartelle in futuro, ma per ora spero solo di copiarlo in C: \ Links \ 1234 \ 1234.pdf – GISKid

+0

check ['filename_fix_existing (filename)'] (https://github.com/steveeJ/python-wget/blob/master/wget.py#L72) –

risposta

6

A volte è più semplice ricominciare da capo ... Mi scuso se c'è qualche errore di battitura, non ho avuto il tempo di testarlo a fondo.

movdir = r"C:\Scans" 
basedir = r"C:\Links" 
# 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: 
     # I use absolute path, case you want to move several dirs. 
     old_name = os.path.join(os.path.abspath(root), filename) 

     # Separate base from extension 
     base, extension = os.path.splitext(filename) 

     # Initial new name 
     new_name = os.path.join(basedir, base, filename) 

     # If folder basedir/base does not exist... You don't want to create it? 
     if not os.path.exists(os.path.join(basedir, base)): 
      print os.path.join(basedir,base), "not found" 
      continue # Next filename 
     elif not os.path.exists(new_name): # folder exists, file does not 
      shutil.copy(old_name, new_name) 
     else: # folder exists, file exists as well 
      ii = 1 
      while True: 
       new_name = os.path.join(basedir,base, base + "_" + str(ii) + extension) 
       if os.path.exists(newname): 
        shutil.copy(old_name, new_name) 
        print "Copied", old_name, "as", new_name 
        break 
       ii += 1 
+0

Grazie per questo, quando eseguo questo viene visualizzato un errore che dice che "ii" non è definito. Potrebbe essere perché sto usando 2.7 (è compatibile su 3.x con ArcGIS che può essere integrato in seguito con il codice) – GISKid

+2

No, è che ho incasinato. Dovrebbe essere ii = 1 (invece di zero, come abbiamo detto nell'altra risposta) invece di index = 0. – Jblasco

0

direi di avere un problema di rientro, almeno per quanto hai scritto qui:

while not os.path.exists(file + "_" + str(i) + extension): 
    i+=1 
    print "Already 2x exists..." 
    print "Renaming" 
    shutil.copy(path, file + "_" + str(i) + extension) 

dovrebbe essere:

while os.path.exists(file + "_" + str(i) + extension): 
    i+=1 
print "Already 2x exists..." 
print "Renaming" 
shutil.copy(path, file + "_" + str(i) + extension) 

Dai un'occhiata, per favore!

+0

Non ha cambiato nulla, sfortunatamente. – GISKid

+0

Ok, dovremo sapere cosa non funziona esattamente, quindi. – Jblasco

+0

E se potessi aggiornare un po 'il codice con le modifiche che hai fatto, anche se non funzionassero, sarebbe fantastico. – Jblasco

0

Io uso sempre il time-stamp - quindi non la sua possibile, che il file esiste già:

import os 
import shutil 
import datetime 

now = str(datetime.datetime.now())[:19] 
now = now.replace(":","_") 

src_dir="C:\\Users\\Asus\\Desktop\\Versand Verwaltung\\Versand.xlsx" 
dst_dir="C:\\Users\\Asus\\Desktop\\Versand Verwaltung\\Versand_"+str(now)+".xlsx" 
shutil.copy(src_dir,dst_dir) 
Problemi correlati