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 :

Fonction compter dates


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Octobre 2007
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 129
    Par défaut Fonction compter dates
    Bonjour,

    Je cherche à faire une petite macro qui affiche sur un formulaire le résultat du comptage de dates en fonction de quelques critères.
    Ce serait plus simple de le faire sur excel directement avec la formule sommeprod, mais je préfère que l'utilisateur clique sur un bouton et que les données soient affichées sur un formulaire.
    Je me suis inspiré de ce que j'ai trouvé sur ce forum en passant par une fonction:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    Public Function CompterMois(Prod As String, Mois As Integer, Zone As Range) As Integer
     
    For Each c In Zone
    If Range(c).Offset(0, -15).Value = Prod Then
    If IsDate(c) Then If Month(c) = Mois Then CompterMois = CompterMois + 1
    End If
     
    Next c
     
    End Function
    et le code lié à un bouton sur lequel clique l'utilisateur:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    PlageStats = Range("U3:U" & Range("A65536").End(xlUp).Row).Address
     
    FrmStat.IntNb01.Caption = CompterMois("CA", 1, Range(PlageStats))
    FrmStat.IntNb02.Caption = CompterMois("CA", 2, Range(PlageStats))
    FrmStat.IntNb03.Caption = CompterMois("CA", 3, Range(PlageStats))
    FrmStat.IntNb04.Caption = CompterMois("CA", 4, Range(PlageStats))
     
    Load FrmStat
    FrmStat.Show
    Quand je clique sur le bouton, j'ai une erreur d'exécution '1004':
    La méthode 'Range' de l'objet '_Global' a échoué

    et c'est la ligne:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If Range(c).Offset(0, -15).Value = Prod Then
    qui est surlignée.

    Si quelqu'un a une petite idée, je suis preneur...

    Merci d'avance pour votre aide.

  2. #2
    Membre Expert Avatar de wilfried_42
    Homme Profil pro
    Auto-entrepreneur
    Inscrit en
    Novembre 2006
    Messages
    1 427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Auto-entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 427
    Par défaut
    Bonjour

    pas certain, mais essaye ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    For Each c In Zone
    If c.Offset(0, -15).Value = Prod Then
    If IsDate(c) Then If Month(c) = Mois Then CompterMois = CompterMois + 1
    End If
    zone est une plage, c est variant puisque non declaré, il devient à l'usage Range
    essaie de déclarer tes variables, c'est plus lisible par la suite

  3. #3
    Membre confirmé
    Inscrit en
    Octobre 2007
    Messages
    129
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 129
    Par défaut
    Bonjour!

    Merci, tu sais quoi? CA MARCHE!!
    Tu me retires une fière chandelle du pied...

    Encore merci
    On peut dire que c'est résolu!

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

Discussions similaires

  1. [XL-2007] Compter le nombres de cellules différentes d'une colonne en fonction de date
    Par lorin.maxime dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 09/09/2013, 11h31
  2. Fonction VB (Date, Left, InStr, etc) non reconnues
    Par BjornDunkerbeck dans le forum Access
    Réponses: 7
    Dernier message: 21/09/2006, 19h58
  3. Comment lancer une fonction à une date donnée
    Par ideal dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 05/02/2006, 12h52
  4. [CR]Aide sur les fonction de date et plage de date.
    Par Job dans le forum SAP Crystal Reports
    Réponses: 1
    Dernier message: 08/11/2005, 09h19
  5. fonction de date en Excel
    Par spopo dans le forum Excel
    Réponses: 11
    Dernier message: 11/08/2005, 13h36

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