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 :

Optimisation code VBA [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de jawed
    Homme Profil pro
    Comptable
    Inscrit en
    Mars 2004
    Messages
    504
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Algérie

    Informations professionnelles :
    Activité : Comptable
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2004
    Messages : 504
    Par défaut Optimisation code VBA
    Bonsoir a vous tous, Je tiens a vous préciser que je débute en VBA
    le code VBA que je joint supprime toutes les lignes superflus pour en garder que l'essentiel, ma question est es que ont peut réduire les lignes de ce 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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    Sub Test()
    Dim i As Integer, j As Integer
        i = Range("A65536").End(xlUp).Row
        For j = i To 1 Step -1
            If Cells(j, 1) = "!                 Age  Dev Chap.      Compte                     Nom                           Intitule                            !" Then
                Rows(j).Delete
            End If
        Next j
        For j = i To 1 Step -1
            If Cells(j, 1) = "! Agence ......: 00512-AP TLEMCEN                                                                                                  !" Then
                Rows(j).Delete
            End If
        Next j
        For j = i To 1 Step -1
            If Cells(j, 1) = "------------------------------------------------------------------------------------------------------------------------------------" Then
                Rows(j).Delete
            End If
        Next j
        For j = i To 1 Step -1
            If Cells(j, 1) = "!                                                                                                                                  !" Then
                Rows(j).Delete
            End If
        Next j
        For j = i To 1 Step -1
            If Cells(j, 1) = "! BANQUE NATIONALE D'ALGERIE                                                                                          CTB-102-3283 !" Then
                Rows(j).Delete
            End If
        Next j
        For j = i To 1 Step -1
            If Cells(j, 1) = "! Compte No  ..: 00512 DZD 220021     0300000075-24     ALGERIE TELECOM SPA                CCdzd entr n .financ privees            !" Then
                Rows(j).Delete
            End If
        Next j
        For j = i To 1 Step -1
            If Cells(j, 1) = "! No Client  ..: 0064800001                                                                                                        !" Then
                Rows(j).Delete
            End If
        Next j
        For j = i To 1 Step -1
            If Cells(j, 1) = "!Date compta!Date valeur!Util!Exo! No piece  !No eve!Ope!            Libelle             !       Debit        !       Credit       !" Then
                Rows(j).Delete
        End If
        Next j
        For j = i To 1 Step -1
            If Left(Cells(j, 1), 6) = "! Date" Then
                Rows(j).Delete
        End If
        Next j
        For j = i To 1 Step -1
            If Left(Cells(j, 1), 57) = "!           !           !    !   !           !      !   !" Then
                Rows(j).Delete
        End If
         Next j
            For j = i To 1 Step -1
            If Left(Cells(j, 1), 67) = "!                                      HISTORIQUE DES MOUVEMENTS DU" Then
                Rows(j).Delete
        End If
        Next j
    End Sub
    Cordialement

  2. #2
    Expert confirmé
    Homme Profil pro
    Electrotechnicien
    Inscrit en
    Juillet 2016
    Messages
    3 241
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Electrotechnicien

    Informations forums :
    Inscription : Juillet 2016
    Messages : 3 241
    Par défaut
    Bonjour,

    Comme ceci:
    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
    Sub Test()
        Dim i As Integer, j As Integer
        i = Range("A65536").End(xlUp).Row
        For j = i To 1 Step -1
            If Cells(j, 1) = "!                 Age  Dev Chap.      Compte                     Nom                           Intitule                            !" Or _
             Cells(j, 1) = "! Agence ......: 00512-AP TLEMCEN                                                                                                  !" Or _
             Cells(j, 1) = "------------------------------------------------------------------------------------------------------------------------------------" Or _
             Cells(j, 1) = "!                                                                                                                                  !" Or _
             Cells(j, 1) = "! BANQUE NATIONALE D'ALGERIE                                                                                          CTB-102-3283 !" Or _
             Cells(j, 1) = "! Compte No  ..: 00512 DZD 220021     0300000075-24     ALGERIE TELECOM SPA                CCdzd entr n .financ privees            !" Or _
             Cells(j, 1) = "! No Client  ..: 0064800001                                                                                                        !" Or _
             Cells(j, 1) = "!Date compta!Date valeur!Util!Exo! No piece  !No eve!Ope!            Libelle             !       Debit        !       Credit       !" Or _
             Left(Cells(j, 1), 6) = "! Date" Or _
             Left(Cells(j, 1), 57) = "!           !           !    !   !           !      !   !" Or _
             Left(Cells(j, 1), 67) = "!                                      HISTORIQUE DES MOUVEMENTS DU" Then Rows(j).Delete
        Next j
    End Sub
    Cdlt

  3. #3
    Membre éclairé Avatar de jawed
    Homme Profil pro
    Comptable
    Inscrit en
    Mars 2004
    Messages
    504
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Algérie

    Informations professionnelles :
    Activité : Comptable
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2004
    Messages : 504
    Par défaut
    Bonjour ARTURO83
    C'est claire, parfait et même nettement plus rapide
    Cordialement

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

Discussions similaires

  1. [XL-2013] Problème d'optimisation code VBA
    Par Tansquer dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 06/07/2018, 15h28
  2. [XL-2010] optimisation code vba
    Par barrybarr dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 08/08/2015, 19h21
  3. [XL-2010] Aide pour optimisation code VBA
    Par adelas93 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 27/11/2014, 13h56
  4. Optimisation code VBA Blocs With
    Par Ariaar dans le forum Général VBA
    Réponses: 0
    Dernier message: 13/12/2012, 17h15
  5. Optimiser code VBA
    Par willytito dans le forum VBA Access
    Réponses: 5
    Dernier message: 19/11/2007, 09h49

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