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 :

Soustraire mois et jours à une date mais de manière comptable (360 jours)


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
    Septembre 2010
    Messages
    120
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 120
    Par défaut Soustraire mois et jours à une date mais de manière comptable (360 jours)
    Bonjour,

    Je souhaite soustraire des mois et jours à une date mais en comptant les mois à 30 jours.
    Ex: retrancher 90 jours à la date du 01/02/2014 et trouver 01/11/2013 et non 03/11/2013
    Merci de votre aide

  2. #2
    Membre émérite
    Homme Profil pro
    Programmeur analyste
    Inscrit en
    Février 2009
    Messages
    546
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : Canada

    Informations professionnelles :
    Activité : Programmeur analyste
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2009
    Messages : 546
    Par défaut
    Je ne sais pas si cela fonctionne dans tout les cas mais c'est un début
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Dim nombre_mois As Integer
    Dim nombre_jour As Integer
    Dim Date_1 As Date
     
    Date_1 = "01-02-2014"
    nombre_jour = 90
    nombre_mois = Round(90 / 30)
     
    MsgBox DateAdd("d", -(nombre_jour + nombre_mois), Date_1)

  3. #3
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Par défaut
    Bonsoir,

    Je ne sais pas si ceci te conviendras ? A creuser :
    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
     
    Sub Test()
     
        Dim LaDate As Date
     
        LaDate = CDate("01/02/2014")
     
        MsgBox Mois30Jours(LaDate, 90)
     
    End Sub
     
    Function Mois30Jours(LaDate As Date, _
                         NBJoursRetires As Integer) As Date
     
        Dim D As Date
        Dim NBJours As Integer
     
        D = LaDate - NBJoursRetires
     
        If NBJoursRetires > 29 Then NBJours = Day(LaDate) - Day(D)
     
        Mois30Jours = Format(D + NBJours, "dd/mm/yyyy")
     
    End Function
    Hervé.

  4. #4
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Par défaut
    Comme la fonction est typée Date, tu peux virer Format :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Mois30Jours = D + NBJours
    Hervé.

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    120
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 120
    Par défaut
    Bonsoir,

    Merci à tous les deux, mais je n'ai pas tout à fait la réponse peut être que mon exemple n'était pas assez parlant.
    mon exemple se compose de 5 colonnes sur x lignes.

    A1= Date d'effet (01/02/2014)
    B1= 1 an
    C1= 6 mois
    D1= 15jours
    E1= date rectifiée (mon résultat)

    Avec la formule ci dessous
    E1=DATE(ANNEE(A1)-B1;MOIS(A1)-C1;JOUR(A1))-D1

    j'arrive au résultat E1= 17/07/2012 au lieu de 16/07/2012
    je n'ai donc pas un calcul sur une année à 360 jours et 1 mois à 30 jours.

    En espérant avoir été plus clair
    Merci d'avance

Discussions similaires

  1. [SQL] une date mais sans les jours
    Par cyberps2 dans le forum Requêtes
    Réponses: 7
    Dernier message: 05/06/2008, 15h53
  2. [Dates] Soustraire un jour à une date
    Par griese dans le forum Langage
    Réponses: 8
    Dernier message: 24/01/2007, 14h18
  3. [VBA-E] soustraire un jour à une date en VBA
    Par fast&furious dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 04/01/2007, 21h42
  4. Réponses: 2
    Dernier message: 03/01/2006, 14h58
  5. [Dates] Soustraire un nombre de jour à une date
    Par lesgars dans le forum Langage
    Réponses: 2
    Dernier message: 09/12/2005, 14h43

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