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 :

Demande d'aide pour macro vba EXCEL


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    photographe
    Inscrit en
    septembre 2022
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Somme (Picardie)

    Informations professionnelles :
    Activité : photographe

    Informations forums :
    Inscription : septembre 2022
    Messages : 9
    Points : 4
    Points
    4
    Par défaut Demande d'aide pour macro vba EXCEL
    Bonjour à tous,

    Je vous explique mon "probleme"

    Photographe scolaire je cherche une solution pour exporter automatiquement une liste d'eleves sous excel ( colonne A Nom Colonne B Prénom ) vers leur photos respectives

    1er nom prenom -> 1ere photo etc etc

    j'ai déjà une version "beta" qui marche (dossier racine c:\TEMP pour les photos a modifier ) mais j'aimerai l'améliorer en mettant deux boutons supplémentaires : DOSSIER SOURCE et dossier DESTINATION

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub rename()
       Dim StrFile As String
       Dim WD As String
       WD = "D:\temp\"
        StrFile = Dir(WD)
            Set Rng = Range("Tab")
                For Each c In Rng
                If c.Next.Value <> "" Then
                    Name WD + StrFile As WD + UCase(c.Value) + " " + UCase(c.Next.Value) + ".jpg"
                     StrFile = Dir
                End If
                Next
    End Sub



    cela me permettrai de gagner du temps.

    Merci par avance

  2. #2
    Expert confirmé
    Homme Profil pro
    retraité
    Inscrit en
    juin 2012
    Messages
    3 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : retraité
    Secteur : Associations - ONG

    Informations forums :
    Inscription : juin 2012
    Messages : 3 133
    Points : 5 429
    Points
    5 429
    Par défaut
    Bonjour,

    Quelque chose de ce genre:
    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
    29
    30
    31
    32
    33
    Option Explicit
     
    Sub Rename()
        Dim sDossSource As String, sDossDest As String, sFile As String, c As Range
        sDossSource = DossierChoisi()
        sDossDest = DossierChoisi()
        If MsgBox("Transférer / renommer les fichiers" & vbLf & _
                  "        du dossier " & sDossSource & vbLf & _
                  "dans le dossier " & sDossDest, _
                  vbYesNo + vbDefaultButton2, "Oui/Non?") = vbYes Then
            sFile = Dir(sDossSource)
            For Each c In Range("Tab")
                If c.Next.Value <> "" Then
                    FileCopy sDossSource + sFile, sDossDest + UCase(c.Value) + " " + UCase(c.Next.Value) + ".jpg"  '--- copie/renomme la photo
                    Kill sDossSource + sFile  '--- supprime la photo
                    sFile = Dir
                End If
            Next
        End If
    End Sub
     
    Public Function DossierChoisi() As String
        DossierChoisi = ""
        With Application.FileDialog(4)          '--- 4 = msoFileDialogFolderPicker
            .InitialFileName = "D:\"
            .AllowMultiSelect = False
            .InitialView = 2                    '--- 2 = msoFileDialogViewDetails
            .Title = "Cliquer sur le dossier puis cliquer sur OK"
            If .Show <> 0 Then
                DossierChoisi = .SelectedItems(1) & "\"
            End If
        End With
    End Function
    L'utilisation de c.Next me semble assez bizarre, mais bon, je laisse.

    Cordialement.

  3. #3
    Candidat au Club
    Homme Profil pro
    photographe
    Inscrit en
    septembre 2022
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Somme (Picardie)

    Informations professionnelles :
    Activité : photographe

    Informations forums :
    Inscription : septembre 2022
    Messages : 9
    Points : 4
    Points
    4
    Par défaut
    super ca marche bien

    et si je veux juste un dossier source et que ca modifie directement les noms de photo sans demander de dossier de destination?

  4. #4
    Expert confirmé
    Homme Profil pro
    retraité
    Inscrit en
    juin 2012
    Messages
    3 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : retraité
    Secteur : Associations - ONG

    Informations forums :
    Inscription : juin 2012
    Messages : 3 133
    Points : 5 429
    Points
    5 429
    Par défaut
    Alors, simplifier la première routine:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Sub Rename()
        Dim sDoss As String As String, sFile As String, c As Range
        sDoss = DossierChoisi()
        If MsgBox("Renommer les fichiers du dossier " & sDoss, _
                  vbYesNo + vbDefaultButton2, "Oui/Non?") = vbYes Then
            sFile = Dir(sDoss)
            For Each c In Range("Tab")
                If c.Next.Value <> "" Then
                    Name sDoss + sFile As sDoss + UCase(c.Value) + " " + UCase(c.Next.Value) + ".jpg"  '--- renomme la photo
                    sFile = Dir
                End If
            Next
        End If
    End Sub
    Cdt

  5. #5
    Candidat au Club
    Homme Profil pro
    photographe
    Inscrit en
    septembre 2022
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Somme (Picardie)

    Informations professionnelles :
    Activité : photographe

    Informations forums :
    Inscription : septembre 2022
    Messages : 9
    Points : 4
    Points
    4
    Par défaut
    Erreur de syntaxe

    sub rename en jaune et "Dim sDoss As String As String, sFile As String, c As Range" en bleu

  6. #6
    Expert confirmé
    Homme Profil pro
    retraité
    Inscrit en
    juin 2012
    Messages
    3 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : retraité
    Secteur : Associations - ONG

    Informations forums :
    Inscription : juin 2012
    Messages : 3 133
    Points : 5 429
    Points
    5 429
    Par défaut
    Effectivement:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim sDoss As String, sFile As String, c As Range
    Cordialement

Discussions similaires

  1. [Debutant] Aide pour macro VBA
    Par sousou94 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 05/09/2010, 06h07
  2. Aide pour code VBA Excel
    Par NEC14 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 01/02/2008, 09h33
  3. demande d'aide pour macro
    Par Mom's dans le forum Macros et VBA Excel
    Réponses: 18
    Dernier message: 18/12/2007, 00h49
  4. [VBA-E][débutant]aide pour macro sous excel
    Par julyBL dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 09/06/2006, 22h42
  5. [VBA-E] aide pour macro sur excel
    Par letoulouzin31 dans le forum Macros et VBA Excel
    Réponses: 21
    Dernier message: 24/05/2006, 11h29

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