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 :

Macro suppression lignes en fonction plusieurs conditions


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Juillet 2013
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Juillet 2013
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Macro suppression lignes en fonction plusieurs conditions
    Bonjour,

    Je viens de m'inscrire car je n'ai pas trouvé un sujet me permettant de trouver la solution par moi-même. Je suis novice en macros (je commence aujourd'hui...).
    Ma question est la suivante:
    J'ai une balance générale (comptabilité) de 3 colonnes: colonne A ==> numéro de compte comptable ; colonne B ==> libellé de compte comptable ; colonne C ==> solde du compte. Petite précision, les comptes comptables sont tous composés de 8 caractères (exemple: 1000000)
    Avant d'exploiter cette balance générale, je dois faire quelques retraitements (qui peuvent être assez longs).
    Premier retraitement: supprimer les lignes dont les comptes comptables (colonne A) commencent par "T"
    Deuxième retraitement: supprimer les lignes dont les comptes comptables (colonne A) commencent par "8"
    Troisième retraitement : supprimer les lignes dont les comptes comptables (colonne A) commencent par "9"
    ==> J'ai réussi à bidouiller une formule qui me les identifie: if((OR((MID(A2;1;1)="T");(MID(A2;1;1)="8");(MID(A2;1;1)="9"));"à supprimer";A2)
    Le problème est que je n'arrive pas à supprimer la ligne via cette formule (j'utilise une formule "if" pour les identifier).

    Quatrième et dernier retraitement: transformer les comptes comptables qui commencent par "I" en un véritable compte comptable. Exemple: I222222 devient 22222220. pour cela, j'utilise habituellement la formule (dans le cas où I222222 est en cellule A1): =Right(A1;7)*10

    J'espère que l'exposé des différents retraitements est clair. Ce que je chercher à faire c'est supprimer les lignes des comptes T, 8 et 9 (pas seulement effacer le contenu de la ligne mais la supprimer) et transformer le compte I.
    Est-ce que vous pourriez-m'aider pour automatiser tout cela via une macro ? Je précise que je vraiment débutant !

  2. #2
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    1 733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 1 733
    Points : 2 553
    Points
    2 553
    Par défaut
    Remplace les trois petits points par le numero de la colonne ou tu as ton à supprimer écrit..

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    numerocolonne=...
     
    If Cells(i, numerocolonne)="à supprimer" then
    Cells(i, numerocolonne).EntireRow.Delete 
    End If

  3. #3
    Nouveau Candidat au Club
    Inscrit en
    Juillet 2013
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Juillet 2013
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Merci pour ta réponse.
    Comme je le disais, je suis vraiment novice. Où dois-je écrire ta réponse ? Il faut créer une nouvelle macro ?
    Est-ce que je dois remplacer "cells" et "numérocolonne". Je suppose que oui mais par quoi ?
    J'espère que je ne te paraîtrai pas trop idiot !
    Encore merci !

  4. #4
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    1 733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 1 733
    Points : 2 553
    Points
    2 553
    Par défaut
    ==> J'ai réussi à bidouiller une formule qui me les identifie:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if((OR((MID(A2;1;1)="T");(MID(A2;1;1)="8");(MID(A2;1;1)="9"));"à supprimer";A2)
    Le problème est que je n'arrive pas à supprimer la ligne via cette formule (j'utilise une formule "if" pour les identifier).


    Supposons que tu aies marqué ça dans la colonne F ( A = 1 B = 2 F = 6 )

    Tu cliques sur ALT F11 et tu crees un module tu copies colles ADAPTES et fait tourner

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub supprimer
    Dim i as long
    numerocolonne=6
     
    For i = 1 to Range("A1").end(Xldown).row
    If Cells(i, numerocolonne)="à supprimer" then
    Cells(i, numerocolonne).EntireRow.Delete 
    End If
    Next i
    End Sub

Discussions similaires

  1. Suppression ligne en fonction de deux cellules
    Par jamesdu75 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 18/04/2013, 17h27
  2. [XL-2003] Macro suppression ligne avec condition
    Par jenifer699 dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 21/08/2012, 12h43
  3. [XL-2003] Macro suppression ligne avec condition 3 mots
    Par jenifer699 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 20/08/2012, 17h45
  4. [XL-2007] macros suppression ligne
    Par ronin.01 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 01/03/2011, 19h35
  5. VBS - Suppression ligne en fonction d'un texte
    Par arnaudbzh dans le forum VBScript
    Réponses: 1
    Dernier message: 09/07/2009, 13h42

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