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 :

SUMIFS--formule - erreur 13-excel VBA


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Homme Profil pro
    intéressé
    Inscrit en
    Décembre 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : intéressé
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2012
    Messages : 10
    Par défaut SUMIFS--formule - erreur 13-excel VBA
    Bonjour,

    Je suis pas très doué en VBA mais j'ai besoin d'aide...

    Je voudrais sur une plage donné, affichier des résultats tirés d'une autre plage d'un onglet différent à partir de la formule "SUMIFS":

    J'ai des méssages d'erreur de type "13". Quelqu'un peut relire mon code et m'apporter une aide....
    voici mon code:

    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
    Sub ligneremplies()
     
    Dim f As Integer
    Dim qname, qdb, qdf, qqty As Range
    Dim qnom, qdate As Range
    Dim T As Double
    Dim AB As Long
    f = Sheets("TESTCODE").Range("F65536").End(xlUp).Row
    Set qname = Sheets("TESTCODE").Range("E1:E" & f)
    Set qdb = Sheets("TESTCODE").Range("F1:F" & f)
    Set qdf = Sheets("TESTCODE").Range("G1:G" & f)
    Set qqty = Sheets("TESTCODE").Range("H1:H" & f)
     
    Sheets("Planning rotation").Range("XM11:BID359").Select '= T
    Set qnom = Sheets("Planning rotation").Range("F11:F359")
    Set qdate = Sheets("Planning rotation").Range("XM7:BID7")
     
    Range("XM11:BID359").Value = WorksheetFunction.SumIfs(qqty, qname = qnom, qdb <= qdate, qdf >= qdate)
     
     
    End Sub

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 569
    Détails du profil
    Informations personnelles :
    Âge : 62
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 569
    Par défaut
    salut
    A priori, mais sans certitude a cette heure là, tes déclarations dont les noms commencent par Q sont des ranges
    T et AB sont des nombres mais n'apparaissent pas dans les critères
    dans le code tous tes "set" déterminent des ranges et noms des nombres
    je ne connais pas sumif, j'ai regardé a somme.si et il te faut un critère, et le nombre d'argument ne correspond pas.
    si ça peut t'aider ..

  3. #3
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonjour le forum, expertdev, alsimbad,
    je ne connais pas sumif, j'ai regardé a somme.si et il te faut un critère, et le nombre d'argument ne correspond pas.
    si ça peut t'aider ..
    Non, Sumifs (avec un "s") remplace "SOMME.SI.ENS", où plusieurs critères peuvent être déclarés, je crois que cette fonction existe depuis Excel 2007.

    Mais il est vrai que les variables sont mal déclarées, mal référencées et que la formule comporte des erreurs car les critères ne peuvent pas être des plages comme dans "SOMME.si".

    Un petit fichier m'aiderais à orienter expertdev

    Bonne journée à tou(te)s
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  4. #4
    Membre habitué
    Homme Profil pro
    intéressé
    Inscrit en
    Décembre 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : intéressé
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2012
    Messages : 10
    Par défaut fichier test exemple SUMIFS
    Bonjour casefayere,

    Merci pour vos réponses, voici mon fichier à titre d'exemple.
    Un exemple de mon fichier car il est lourd et comporte plusieurs lignes et colonnes. Je voudrais remplacers somme.si.ens par la même formule en code VBA.

    Merci
    Fichiers attachés Fichiers attachés

  5. #5
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonjour Experdev,

    Je vais regarder mais en attendant corriges ton 1er message en respectant les balises codes, en pratiquant comme ci-dessous, ou pendant une redaction comme ici :
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  6. #6
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    En regardant ton fichier et, sutout, ta formule, je ne comprends pas quelle plage veux-tu totaliser.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    'quelle plage car la formule est incorrecte ?
    .Range("XM11:BID359") = WorksheetFunction.SumIfs(qqty, qname = qnom, qdb <= qdate, qdf >= qdate)
    'et quels critères ?
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

Discussions similaires

  1. Gestion d'erreurs userform excel vba
    Par OursTortue dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 04/03/2015, 10h58
  2. [XL-2010] Erreur 1004 excel vba
    Par sosoboss dans le forum Excel
    Réponses: 5
    Dernier message: 24/02/2015, 17h31
  3. [XL-2007] Excel-VBA : Formule longue sur plusieurs lignes erreur fin d'instruction
    Par Pauline1374 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 04/03/2014, 18h46
  4. [XL-2010] Erreur 1004 EXCEL VBA
    Par Invité dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 03/02/2014, 22h48
  5. Problème - Erreur 438 - Excel vba 2003
    Par Nanoucha dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 08/03/2010, 21h27

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