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 :

problème de code pour macro


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2013
    Messages : 8
    Points : 9
    Points
    9
    Par défaut problème de code pour macro
    Bonjour,

    J'ai une macro vba à faire pour un classeur excel mais je suis loin de m'y connaître.
    Voici ce que doit faire mon code :
    dès qu'une cellule de la colonne AH est modifiée, renseigner la date de cette modification dans la cellule d'à côté (AI).
    Voici ma trame de code, qui ne marche pas du tout :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Sub change()
    Dim modif As Boolean
    Private Sub Workbook_BeforeClose(Cancel As Boolean)
    a = 6
        For i = 6 To 78
        Range("AH" & i) = a
        a = a + 1
            If modif = True Then
            Sheets("polyvalence uap Multi").Range("AI" & i).Value = Format(Date, "dd/mm/yyyy")
            End If
        Next i
    End Sub
    Pouvez-vous m'aider ?
    Merci

  2. #2
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    Bonjour,

    Ci dessous un petit coup de pouce

    On utilise l'évenement change de la feuille.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub Worksheet_Change(ByVal Target As Range)
    If Split(Target.Address, "$")(1) = "AH" Then
        Target.Offset(0, 1).Value = Format(Now, "dd/mm/yyyy")
    End If
    End Sub
    Jérôme

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2013
    Messages : 8
    Points : 9
    Points
    9
    Par défaut
    Merci beaucoup, ça marche très bien!

    Si ça te dérange pas, j'aimerais aussi savoir comment comparer la date renseignée dans la cellule (AI) avec la date d'aujourd'hui.
    Si le délais est supérieur à 3 mois, la cellule AH prend la valeur d'une autre cellule (X86).
    Si tu as une idée?
    Merci

  4. #4
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    Une méthode consiste a utiliser la formule Datedif (formule caché et non documenté dans excel)

    Exemple, le m correspondant à un écart en mois
    La fonction DATEDIF() permet de calculer la différence entre deux dates en années, mois et jours.
    Cette fonction n'est pas documentée dans l'aide Excel, mais elle s'avère bien pratique pour effectuer des calculs sur des âges ou des dates d'échéance.

    Syntaxe : DATEDIF (Date1; Date2;Intervalle)
    Date 1 est la date de Départ
    Date 2 est la date de Fin
    Intervalle peut prendre différentes valeurs:
    "y" : différence en années
    "m" : différence en mois
    "d" : différence en jours
    "ym" : différence en mois, une fois les années soustraites
    "yd" : différence en jours, une fois les années soustraites
    "md" : différence en jours, une fois les années et les mois soustraits
    à noter : Date2 doit toujours être supérieure ou égale à Date1
    Jérôme

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2013
    Messages : 8
    Points : 9
    Points
    9
    Par défaut merci beaucoup, je vais essayer
    merci beaucoup, je vais essayer

Discussions similaires

  1. Problème de code pour dérivée
    Par Vincent32 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 05/10/2011, 07h13
  2. probléme de code pour mot de passe oublié
    Par Jaafar_scorpion dans le forum Android
    Réponses: 5
    Dernier message: 10/06/2011, 12h34
  3. problème de code pour police
    Par demando77 dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 24/03/2008, 18h42
  4. [VBA-E]problème d'indice pour macro dans perso.xls
    Par fred38 dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 01/05/2007, 23h33

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