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 Trier par type de variable [XL-2013]


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
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2017
    Messages : 9
    Par défaut VBA Trier par type de variable
    Bonjour,

    Je cherche à faire une feuille calcul faisant la somme d'heures passés en maintenance. Pour cela, il faut trier les lignes en fonction d'une certaine colonne puis faire la somme des heures notées dans une autre colonne. Jusque là, rien de sorcier, j'y suis arrivé seul. C'était sans compter les erreurs de saisi. En effet, lors de l'exécution de ma macro, j'ai eu la fameuse erreur 13 : incompatibilité de type. Après investigation, j'ai trouvé des cases rempli avec du texte dans la colonne des heures (impossible à additionner donc). D'où l'erreur. Je cherche donc un moyen de supprimer ces lignes, inexploitables, ou de les trier au moins.

    Merci d'avance

    Pour un info 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
    Sub Count()
    Dim nligne As Long
    Dim TotHeures As Double
    Dim HeuresPanne As Double
     
    nligne = Range("B2").CurrentRegion.Rows.Count
    For i = (nligne + 1) To 1 Step -1
    TotHeures = TotHeures + Cells(i, 8).Value
    Next
    For i = (nligne + 1) To 1 Step -1
    If Cells(i, 6).Value = "902" Then
    HeuresPanne = HeuresPanne + Cells(i, 8).Value
    End If
    Next
    Cells(2, 1).Value = TotHeures
    Cells(3, 1).Value = HeuresPanne
    Cells(4, 1).Value = (HeuresPanne / TotHeures)
    End Sub

  2. #2
    Expert confirmé Avatar de BENNASR
    Homme Profil pro
    Responsable comptable & financier
    Inscrit en
    Décembre 2013
    Messages
    2 974
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Responsable comptable & financier
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2013
    Messages : 2 974
    Par défaut
    Bonjour
    A mon avis c'est plus rapide et peut être ça te permet de surmonter ton message d'erreur de travailler avec un tableau :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    Sub Count()
    Dim i As Long
    Dim Tablo
    Tablo = Sheets("Tonfiche").Range("A2", "H" & Sheets("Tonfiche").Range("H" & Rows.Count).End(xlUp).Row)
     For i = LBound(Tablo, 1) To UBound(Tablo, 1)
        If Tablo(i, 6) = "902" Then
            HeuresPanne = HeuresPanne + Tablo(i, 8)
        End If
    Next i
    Sheets("Tonfiche").Range("A3") =  HeuresPanne
    End Sub

  3. #3
    Membre Expert
    Femme Profil pro
    Ingénieur
    Inscrit en
    Octobre 2016
    Messages
    1 703
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Indre et Loire (Centre)

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

    Informations forums :
    Inscription : Octobre 2016
    Messages : 1 703
    Par défaut
    Bonjour,
    Tu peux ajouter une ligne à ton tableau avec la fonction =ESTTEXTE() et ne faire l'addition que sur les cellules pour lesquelles cette fonction renvoie VRAI.
    Sinon, dans ta procédure, tu peux ajouter une condition :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If IsNumeric(laCellule) Then ajouter à la somme

  4. #4
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2017
    Messages : 9
    Par défaut Résolu
    Merci pour vos réponses.

    BENNSAR travailler par tableau est bien pensé, cependant je débute sur vba je préfère donc garder ma méthode pour l'instant, et puis cela me permet de pratiquer un peu la fonction que viens de me donner riaolle. (je garde les tableaux dans un coin de ma tête).

    riaolle ton idée marche niquel dans mon programme.

    Encore un grand merci à vous deux !

  5. #5
    Membre Expert
    Femme Profil pro
    Ingénieur
    Inscrit en
    Octobre 2016
    Messages
    1 703
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Indre et Loire (Centre)

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

    Informations forums :
    Inscription : Octobre 2016
    Messages : 1 703
    Par défaut
    Au passage, plutôt que de créer une procédure en VBA, ne peux tu pas utiliser SOMME.SI.ENS ?

  6. #6
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2017
    Messages : 9
    Par défaut
    Si, SOMME.SI.ENS aurait été tout à fait adapté.

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

Discussions similaires

  1. outlook vba trier par nombre d'élement
    Par jpctop dans le forum Outlook
    Réponses: 0
    Dernier message: 20/08/2015, 16h08
  2. Trier par nom de variables
    Par RapH0304 dans le forum Débutez
    Réponses: 1
    Dernier message: 27/12/2012, 19h53
  3. Réponses: 7
    Dernier message: 09/05/2007, 19h35
  4. [VBA]Trier les valeur d une liste par ordre croissant
    Par PierrotKun dans le forum VBA Access
    Réponses: 1
    Dernier message: 30/03/2007, 09h37
  5. Trier les fichiers par type et les afficher par groupe ...
    Par KneXtasY dans le forum Autres Logiciels
    Réponses: 4
    Dernier message: 18/09/2005, 18h50

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