begin process at 2010 02 10 02:51:17
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Fichier / Disque

 > COPIE UNE ARBORESCENCE DE FICHIERS AVEC VÉRIFICATION DES FICHIERS COPIÉS

COPIE UNE ARBORESCENCE DE FICHIERS AVEC VÉRIFICATION DES FICHIERS COPIÉS


 Information sur la source

Note :
Aucune note
Catégorie :Fichier / Disque Niveau :Débutant Date de création :02/06/2003 Date de mise à jour :02/06/2003 15:41:30 Vu / téléchargé :4 693 / 703

Auteur : Brain

Ecrire un message privé
Site perso
Commentaire sur cette source (0)
Ajouter un commentaire et/ou une note

 Description

Un programme qui copie les fichiers d'un répertoire à un autre en traitant les sous dossiers (fonction récursive) et qui gère si les fichiers on bien été copié.
supprime aussi certains espaces en fin de noms pour la compatibilité entre Mac et PC.
J'ai fait ce programme pour vérifier la bonne sauvegarde des fichiers d'un mac pour les transférer vers un PC
Permet d'obtenir une liste des fichiers qui n'ont pas été copiés.

Source

  • procedure ChercherFichier(Repertoire,Repcourt: string);
  • var
  • R: Integer;
  • SearchRec: TSearchRec;
  • nomdest,nomcourt,nomtemp: String;
  • begin
  • begin
  • R := FindFirst(Repertoire + '\*', faAnyFile, SearchRec);
  • try
  • while R = 0 do
  • begin
  • form1.LblNbListe.Caption:= inttostr(Form1.RichEditListeFichieraCopier.Lines.Count);
  • application.ProcessMessages;
  • nomdest:=copy(Repertoire + '\' + SearchRec.Name, 3, StrLen(Pchar(Repertoire + '\' + SearchRec.Name)) - 2) ;
  • nomcourt:=ExtractShortPathName(Repcourt + '\' +SearchRec.Name);
  • if nomcourt='' then
  • begin
  • nomtemp:='"' + Repcourt + '\' +SearchRec.Name+' "';
  • nomcourt:=nomtemp;
  • nomcourt:=ExtractShortPathName('"' + Repcourt + '\' +SearchRec.Name+' "');
  • nomcourt:=Repcourt;
  • end;
  • if (SearchRec.Attr <> 16) and (SearchRec.Attr <> 17) then
  • begin
  • Form1.RichEditListeFichieraCopier.Lines.Add(Repertoire + '\' + SearchRec.Name);
  • // Form1.RichEdit4.Lines.Add(nomdest);
  • form1.RichEditNomCourtdesFichiers.Lines.Add(nomcourt);
  • end
  • else if (SearchRec.Name <> '..') and (SearchRec.Name <> '.') then
  • try
  • //remplace les '**** \*****' par '****\****'
  • nomdest:=ReplaceRegExpr(' \\',nomdest,'\');
  • CreateDir(Form1.EditDest.Text + nomdest);
  • if not DirectoryExists(Form1.EditDest.Text + nomdest) then
  • Form1.RichEditErreurRepertoire.Lines.add('"' + Repertoire + '\' + SearchRec.Name + '"');
  • ChercherFichier(Repertoire + '\' + SearchRec.Name, ExtractShortPathName(Repcourt + '\' + SearchRec.Name));
  • except
  • Form1.RichEditErreurRepertoire.Lines.add('"' + Repertoire + '\' + SearchRec.Name + '"');
  • end;
  • R := FindNext(SearchRec);
  • end;
  • finally
  • FindClose(SearchRec);
  • end;
  • end;
  • end;
  • procedure TForm1.BtnListerClick(Sender: TObject);
  • begin
  • if not DirectoryExists(EditDest.Text + copy(pchar(EditSource.Text), 3, strlen(pchar(EditSource.Text) - 2))) then
  • CreateDir(EditDest.Text + copy(pchar(EditSource.Text), 3, strlen(pchar(EditSource.Text) - 2)));
  • ChercherFichier(EditSource.Text,EditSource.Text);
  • end;
  • procedure TForm1.BtnCopierClick(Sender: TObject);
  • var
  • i: integer;
  • filename: string;
  • begin
  • for i := 0 to RichEditListeFichieraCopier.Lines.Count do
  • begin
  • if BtnLister.Tag<>0 then
  • begin
  • BtnLister.Tag:=0;
  • exit;
  • end;
  • try
  • form1.LblNBCopies.Caption:= inttostr(i);
  • filename := EditDest.Text + copy(RichEditListeFichieraCopier.Lines[i], 3, StrLen(Pchar(RichEditListeFichieraCopier.Lines[i])) - 2);
  • filename:=ReplaceRegExpr(' \\',filename,'\');
  • CopyFile(Pchar(RichEditListeFichieraCopier.Lines[i]), Pchar(filename), false);
  • if not FileExists(filename) then
  • begin
  • RichEditFichiersMalCopies.Lines.Add(RichEditListeFichieraCopier.Lines[i]);
  • //pour connaitre le nomcourt des fichiers mal copiés
  • //RichEdit6.Lines.Add(RichEditListeFichiersaCopier.Lines[i]);
  • end;
  • LblNbMalCopies.Caption:=inttostr(RichEditFichiersMalCopies.Lines.count);
  • except
  • RichEditFichiersMalCopies.Lines.Add(RichEditListeFichieraCopier.Lines[i]);
  • end;
  • application.ProcessMessages;
  • end;
  • end;
  • procedure TForm1.BtnArretCopieClick(Sender: TObject);
  • begin
  • BtnLister.tag:=1;
  • end;
procedure ChercherFichier(Repertoire,Repcourt: string);
var
  R: Integer;
  SearchRec: TSearchRec;
  nomdest,nomcourt,nomtemp: String;
begin
  begin
    R := FindFirst(Repertoire + '\*', faAnyFile, SearchRec);
    try
      while R = 0 do
        begin
      form1.LblNbListe.Caption:=   inttostr(Form1.RichEditListeFichieraCopier.Lines.Count);
      application.ProcessMessages;
          nomdest:=copy(Repertoire + '\' + SearchRec.Name, 3, StrLen(Pchar(Repertoire + '\' + SearchRec.Name)) - 2) ;
          nomcourt:=ExtractShortPathName(Repcourt + '\' +SearchRec.Name);
          if nomcourt='' then
            begin
              nomtemp:='"' + Repcourt + '\' +SearchRec.Name+' "';
              nomcourt:=nomtemp;
              nomcourt:=ExtractShortPathName('"' + Repcourt + '\' +SearchRec.Name+' "');
              nomcourt:=Repcourt;
            end;
          if (SearchRec.Attr <> 16) and (SearchRec.Attr <> 17) then
            begin
              Form1.RichEditListeFichieraCopier.Lines.Add(Repertoire + '\' + SearchRec.Name);
//              Form1.RichEdit4.Lines.Add(nomdest);
              form1.RichEditNomCourtdesFichiers.Lines.Add(nomcourt);

            end

          else if (SearchRec.Name <> '..') and (SearchRec.Name <> '.') then
          try
            //remplace les '**** \*****' par '****\****'
            nomdest:=ReplaceRegExpr(' \\',nomdest,'\');
            CreateDir(Form1.EditDest.Text + nomdest);
            if not DirectoryExists(Form1.EditDest.Text + nomdest) then
              Form1.RichEditErreurRepertoire.Lines.add('"' + Repertoire + '\' + SearchRec.Name + '"');
            ChercherFichier(Repertoire + '\' + SearchRec.Name, ExtractShortPathName(Repcourt + '\' + SearchRec.Name));
          except
            Form1.RichEditErreurRepertoire.Lines.add('"' + Repertoire + '\' + SearchRec.Name + '"');
          end;
          R := FindNext(SearchRec);
        end;
    finally
      FindClose(SearchRec);
    end;
  end;

end;

procedure TForm1.BtnListerClick(Sender: TObject);
begin
  if not DirectoryExists(EditDest.Text + copy(pchar(EditSource.Text), 3, strlen(pchar(EditSource.Text) - 2))) then
    CreateDir(EditDest.Text + copy(pchar(EditSource.Text), 3, strlen(pchar(EditSource.Text) - 2)));
  ChercherFichier(EditSource.Text,EditSource.Text);
end;

procedure TForm1.BtnCopierClick(Sender: TObject);
var
  i: integer;
  filename: string;
begin
  for i := 0 to RichEditListeFichieraCopier.Lines.Count do
    begin
      if BtnLister.Tag<>0 then
        begin
          BtnLister.Tag:=0;
          exit;
        end;
        try
        form1.LblNBCopies.Caption:=   inttostr(i);
        filename := EditDest.Text + copy(RichEditListeFichieraCopier.Lines[i], 3, StrLen(Pchar(RichEditListeFichieraCopier.Lines[i])) - 2);
        filename:=ReplaceRegExpr(' \\',filename,'\');
        CopyFile(Pchar(RichEditListeFichieraCopier.Lines[i]), Pchar(filename), false);
        if not FileExists(filename) then
          begin
            RichEditFichiersMalCopies.Lines.Add(RichEditListeFichieraCopier.Lines[i]);
            //pour connaitre le nomcourt des fichiers mal copiés
            //RichEdit6.Lines.Add(RichEditListeFichiersaCopier.Lines[i]);
          end;
        LblNbMalCopies.Caption:=inttostr(RichEditFichiersMalCopies.Lines.count);
      except
        RichEditFichiersMalCopies.Lines.Add(RichEditListeFichieraCopier.Lines[i]);
      end;
      application.ProcessMessages;
    end;
end;
procedure TForm1.BtnArretCopieClick(Sender: TObject);
begin
  BtnLister.tag:=1;
end;

 Conclusion

je ne modifierai plus ce code puisque la migration est finie.
Tout ce que je peux vous en dire c'est que les Mac c'est vraiment pas à mon gout...

 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Sources du même auteur

Source avec Zip Source avec une capture MÉTÉO, PROGRAMME TV, ANNUAIRE NORMAL ET INVERSÉ, AOL
Source avec Zip Source avec une capture RÉCUPÉRATION MÉTÉO, PROGTV, ANNUAIREINVERSÉ, LOTO ET CONTROL...
AUTOCONNECTION À AOL
CORRECTION DE LA MOLETTE DANS LES DBGRID

 Sources de la même categorie

Source avec Zip SAUVEGARDE DE PLUSIEURS DISQUES/PARTITIONS par danfranjo
Source avec Zip Source avec une capture FICLOCK : LOCKEZ LES FICHIERS par JulioDelphi
Source avec Zip Source avec une capture MODIFICATION DES EXTENSIONS DE FICHIERS par JeremyLecouvert
EXPLORATION RÉCURSIVE DE RÉPERTOIRE par JeremyLecouvert
Source avec Zip OBTENIR LE PROPRIÉTAIRE D'UN FICHIER (WIN32;NTFS) par ILP

Commentaires et avis

Aucun commentaire pour le moment.

 Ajouter un commentaire




Nos sponsors


Sondage...

CalendriCode

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,811 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales