IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

VBA renommage fichier sans ouverture


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2007
    Messages
    173
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Août 2007
    Messages : 173
    Par défaut VBA renommage fichier sans ouverture
    Bonjour,
    Je souhaite faire un batch sur des fichiers en VBA et ca fait un peu que j'ai oublié les subtilités.
    J'ai une serie de fichier avec un prefix commun : "ARRAYSCAN01_140715160003_" et je souhaite changer ce préfix par le prefix :"mamanip".

    Comment dois-je m'y prendre ?

    Merci pour votre aide

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    Sub renommage()
    Dim i As Integer
    Dim fso
    Dim RepC As String, Fichier As String, lefichier As String, nomavt As String, nomapre As String
    i = 0
     
    Rep = "I:\ARRAYSCAN01_140715160003-80-CP\test\images\ARRAYSCAN01_140715160003_"
    Repfin = "I:\ARRAYSCAN01_140715160003-80-CP\test\images\test_"
     
    ' recupération des fichiers C01
    RepC = Rep & "*C01"
    Fichier = Dir(RepC)
     
    ' Boucle sur les fichiers de format xls du répertoire Rep
    Do While Fichier <> ""
      ' selection du fichier à copier
     
    Set fso = CreateObject("Scripting.FileSystemObject")
    ' fso.MoveFile "d:dummytest.txt", "d:dummytest2.txt"
     nomavt = "I:\ARRAYSCAN01_140715160003-80-CP\test\images\A.C01"
     nomapre = "I:\ARRAYSCAN01_140715160003-80-CP\test\images\B.C01"
    fso.MoveFile nomavt, nomapre
     
    i = i + 1
    Fichier = Dir ' Fichier suivant
    Loop
     
    End
    End Sub

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bonjour,

    Nul besoin du FileSystemObject

    Exemple sorti de l'aide
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Dim OldName, NewName
    OldName = "ANCFICH": NewName = "NOUVFICH"    ' Définit les noms de fichiers.
    Name OldName As NewName    ' Renomme le fichier.
     
    OldName = "C:\MONREP\ANCFICH":NewName = "C:\VOTREREP\NOUVFICH"
    Name OldName As NewName    ' Déplace et renomme le fichier.
    Et tu peux détruire les anciens fichiers, si nécessaire, avec Kill

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2007
    Messages
    173
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Août 2007
    Messages : 173
    Par défaut
    Merci, et voila la boucle

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    Sub renommage()
    Dim i As Integer
    Dim RepC As String, Fichier As String, lefichier As String, nomavt As String, nomapre As String, Reppref As String, Repfin As String
    Dim FichierSsufix As String
    i = 0
     
    Rep = "T:\EXPECT\Arrayscan\20140715\ARRAYSCAN01_14071517000320-CP\"
    Reppref = Rep & "ARRAYSCAN01_140715170003_"
    Repfin = Rep & "ARRAYSCAN01_140715160009_"
     
    ' recupération des fichiers C01 dans Rep avec le prefix de Reppref
    RepC = Rep & "*C01"
    Fichier = Dir(RepC)
     
    ' Boucle sur les fichiers de format xls du répertoire Rep
    Do While Fichier <> ""
      FichierSsufix = Mid(Fichier, 25, 36)
     
     nomavt = Rep & Fichier
     nomapre = Repfin & FichierSsufix
     Name nomavt As nomapre
    i = i + 1
    Fichier = Dir ' Fichier suivant
    Loop
     
    End
     
    End Sub

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Toutes versions] ERROR 52 VBA, Ouverture d'un fichier sans l'ouvrir de source externe
    Par studying dans le forum Excel
    Réponses: 0
    Dernier message: 14/01/2013, 11h29
  2. (VBA-E) Erreur sur ouverture de fichier
    Par Stutak dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 27/08/2006, 15h11
  3. Réponses: 4
    Dernier message: 13/06/2006, 15h11
  4. [VBA-E]Ecrire dans un fichier sans l'ouvrir (ou dans un fichier invisible)
    Par bandit boy dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 29/05/2006, 17h14
  5. [VBA-E] cacher l'ouverture fichier excel barre des taches
    Par icicmoi dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 18/05/2006, 17h39

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo