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

Excel Discussion :

incrementation de date avec VBA [Toutes versions]


Sujet :

Excel

  1. #1
    Membre du Club
    Inscrit en
    Mai 2013
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Mai 2013
    Messages : 83
    Points : 45
    Points
    45
    Par défaut incrementation de date avec VBA
    Bonjour,

    J'essaie d’incrémenter une date sous forme dd.mm.yyyy mais que les dernières journée du mois, ce qui donne 31/01/1990 par exemple et 28/02/2003.

    Le problème c'est que avec le mois de février et les années bissextiles, je n'arrive pas a passer a au 29 fevrier et après repasser au 31 mars.

    Voici le code que j'ai actuellement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    For i = 2 To periode
    wsTMP.Cells(i, 4) = Format(endDate, "dd.mm.yyyy")
    endDate = DateAdd("m", 1, endDate)
    Next
    Merci.

  2. #2
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Est-ce que tu as essayé de mettre dans DateEnd la date de début de mois (le 01) et de mettre dans ta fonction Format DateEnd+1 ?

    Autre solution :
    Est-ce que tu as essayé d'utiliser la fonction EoMonth() ? C'est une fonction qui donne la date de fin de mois en fonction d'une date données
    Donc, l'incrément de ta variable devient
    DateEnd = EoMonth(DateEnd+1)

    Bien sûr, pour que l'une ou l'autre de ces solutions marche, il faut que ta variable DateEnd soit réellement une date (nombre de jour) avec l'année incluse.

  3. #3
    Membre du Club
    Inscrit en
    Mai 2013
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Mai 2013
    Messages : 83
    Points : 45
    Points
    45
    Par défaut
    Pour Eomonth, il faut installer des des modules complémentaires ( vu que la fonction n'est pas reconnu dans la version que j'ai), et vu que je suis pas l'utilisateur final, je préféré ne pas mettre en place une solution pareil.

    pour l'utilisation de
    wsTMP.Cells(i, 4) = Format(endDate +1 , "dd.mm.yyyy"
    voici le résultat que j'ai pour les premiere ligne ( la fin des mois de toute l'année 1992) :

    01.02.1992
    01.03.1992
    30.03.1992
    30.04.1992
    30.05.1992
    30.06.1992
    30.07.1992
    30.08.1992
    30.09.1992
    30.10.1992
    30.11.1992
    30.12.1992

  4. #4
    Chroniqueur Actualités
    Avatar de Michael Guilloux
    Homme Profil pro
    Data Consultant
    Inscrit en
    Juillet 2013
    Messages
    2 942
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Data Consultant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2013
    Messages : 2 942
    Points : 88 243
    Points
    88 243
    Billets dans le blog
    2
    Par défaut
    Salut à tous,
    @Info0009, voici excatement ce que Menhir veut dire que je traduis à travers ce exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub ajouter()
    Dim EndDate As Date
    For i = 1 To 5
    EndDate = Cells(i, 1).Value
    'principe : ajouter un jour,pour aller au 1er jour du mois m+1
    'ajoute ensuite 1 mois pour aller au premier jour du mois m+2
    'Et retrancher 1 jour pour venir au dernier jour du mois m+1
      EndDate = DateAdd("d", 1, EndDate)
      EndDate = DateAdd("m", 1, EndDate)
      EndDate = DateAdd("d", -1, EndDate)
     Cells(i, 2).Value = EndDate
     Next
    End Sub
    @ Menhir, est ce qu'il y a des références à activer pour pouvoir utiliser EoMonth? c'est plus simple et ça fait gagner quelques lignes de code.

  5. #5
    Membre du Club
    Inscrit en
    Mai 2013
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Mai 2013
    Messages : 83
    Points : 45
    Points
    45
    Par défaut
    Citation Envoyé par kkm90 Voir le message
    Salut à tous,
    @Info0009, voici excatement ce que Menhir veut dire que je traduis à travers ce exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub ajouter()
    Dim EndDate As Date
    For i = 1 To 5
    EndDate = Cells(i, 1).Value
    'principe : ajouter un jour,pour aller au 1er jour du mois m+1
    'ajoute ensuite 1 mois pour aller au premier jour du mois m+2
    'Et retrancher 1 jour pour venir au dernier jour du mois m+1
      EndDate = DateAdd("d", 1, EndDate)
      EndDate = DateAdd("m", 1, EndDate)
      EndDate = DateAdd("d", -1, EndDate)
     Cells(i, 2).Value = EndDate
     Next
    End Sub
    @ Menhir, est ce qu'il y a des références à activer pour pouvoir utiliser EoMonth? c'est plus simple et ça fait gagner quelques lignes de code.
    Merci, j'ai pu le faire après tes explications.

  6. #6
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par info009 Voir le message
    Pour Eomonth, il faut installer des des modules complémentaires ( vu que la fonction n'est pas reconnu dans la version que j'ai),
    Si tu avais pris la peine de signaler la version dans ton titre, on aurait pu le savoir.

    pour l'utilisation de

    voici le résultat que j'ai pour les premiere ligne ( la fin des mois de toute l'année 1992) :
    Ma réponse était en deux partie. C'est sûr que si tu n'en fait que la moitié, ça ne peut pas marcher.
    Le principe est d'atteindre la date de début de mois (ce qui est plus facile vu que c'est toujours le 1) et de reculer d'un jour.

    Citation Envoyé par kkm90 Voir le message
    @ Menhir, est ce qu'il y a des références à activer pour pouvoir utiliser EoMonth?
    Dans mon 2007, il y a une fonction "FIN.MOIS()".
    Son équivalent anglais, EoMonth" fait partie de la liste des fonctions Excel utilisables en VBA (je suppose qu'elle se trouve dans la bibliothèque Microsoft Excel Object Library).

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

Discussions similaires

  1. Comparer date avec VBA
    Par Radaghast dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 23/07/2012, 22h50
  2. [AC-2003] Problème de dates avec VBA
    Par Ric500 dans le forum VBA Access
    Réponses: 5
    Dernier message: 13/09/2010, 18h39
  3. Réponses: 9
    Dernier message: 19/02/2007, 21h33
  4. Insertion d'une date dans une table avec vba
    Par skeut dans le forum Access
    Réponses: 2
    Dernier message: 21/02/2006, 09h54
  5. [VBA-E] Dates avec année à deux chiffres
    Par BBe8127 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 27/09/2005, 18h23

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