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 ajout d'heure dans plusieurs cellules


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mars 2016
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2016
    Messages : 16
    Par défaut VBA ajout d'heure dans plusieurs cellules
    Bonjour

    Ci dessous ma requête,j'ai des cellules avec une date et une heure(de A3 à A10) je veux garder uniquement l'heure et ajouter pour chaque cellules une heure , ma requête fonctionne mais il ajoute uniquement une heure à la cellule A3 (la première) et mets toutes les autres cellules à la même heure que la première (en l'occurrence A3) et si je réexécute ma requête il ajoute bien une heure à toutes les cellules !!!
    Pouvez-vous m'aider SVP car suis profane en VBA .

    Merci

    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
    Sub Compare()
     
    Dim cell As Range
     
    Columns("A:A").NumberFormat = "hh:mm:ss"
     
    For Each cell In Range("A3")
    If cell.Value > 1 Then
           Range("A3:A10") = Range("A3") + (1 / 24)
     
    End If
     
    Next cell
     
    End Sub

  2. #2
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    Bonsoir,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub Compare()
     
    Dim cell As Range
     
    Columns("A:A").NumberFormat = "hh:mm:ss"
     
    For Each cell In Range("A3:A10")
        If cell.Value > 1 Then
            cell.Value = TimeSerial(Hour(cell), Minute(cell), Second(cell)) + (1 / 24)
        End If
    Next cell
     
    End Sub

  3. #3
    Membre averti
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mars 2016
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2016
    Messages : 16
    Par défaut
    Mille mercis !!! ça fontionne très bien ! comme quoi il vaut mieux s'adresser au bon Dieu qu'à ses saints !!!

    ReBonsoir

    Par contre si je la réexécute il ne rajoute pas une heure ! est-ce normal ?

    Une autre question

    Sur les cellules à 23h et plus il affiche bien 00h xx mais par contre en cliquant sur la cellule il affiche : 01/01/1900 00:22:00

    N'est ce pas un problème de format de la cellule ?

    Merci

  4. #4
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    Bonjour,

    Au temps pour moi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub Compare()
     
    Dim cell As Range
     
    Columns("A:A").NumberFormat = "hh:mm:ss"
     
    For Each cell In Range("A3:A10")
        If cell.Value > 1 Then
            cell.Value = cell.Value + (1 / 24)
        End If
    Next cell
     
    End Sub

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 09/04/2015, 12h09
  2. [XL-2010] VBA ajout de formule dans une cellule
    Par dim597 dans le forum Excel
    Réponses: 0
    Dernier message: 14/05/2013, 10h27
  3. [POI] Ajouter une donnée au format heure dans une cellule
    Par mouss4rs dans le forum API standards et tierces
    Réponses: 0
    Dernier message: 26/02/2012, 12h59
  4. [XL-2003] Macro VBA suppression texte dans plusieurs cellules
    Par demichoux dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 28/06/2011, 15h28
  5. Ajouter des heures dans une cellule date
    Par j.mathieu dans le forum Excel
    Réponses: 3
    Dernier message: 22/01/2010, 14h39

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