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 :

PB rapidité de code


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juin 2016
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2016
    Messages : 44
    Points : 31
    Points
    31
    Par défaut PB rapidité de code
    Bonjour,

    j'ai un code qui fonctionne bien de KIOUANE mais un peu long à exécuter.
    Dans la barre d'état, je vois qu'il a calculé sur 197706 cellules.

    Je souhaite mettre une plage de cellule pour aller plus vite.
    Mon tableau ne change jamais, il va de A3 à E400.

    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
     
    Sub tri()
    Application.ScreenUpdating = False
     
    Dim a, b As Integer
     
     With Sheets("TRI")
        n = .Range("A" & Rows.Count).End(xlUp).Row
        .Range("A3:E" & n).Sort Key1:=Range("B3:B400"), Order1:=xlDescending, Header:= _
            xlNo, OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom, _
            DataOption1:=xlSortTextAsNumbers
     
    End With
     
    For v = 12 To 408 Step 11
      For j = 1 To 13
        For i = n - 1 To 3 Step -1
     
         If Cells(i, 1).Value = v Then
           For y = 1 To n - i
             If Cells(i + y, 1).Value < v Then
                Application.CutCopyMode = False
                Cells(i, 1).EntireRow.Cut
                Cells(i + y + 1, 1).Select
                Selection.Insert Shift:=xlDown
     
     
              Exit For
              End If
            Next
     
         End If
     
      Next
     
     Next
    Next
     
     
    End Sub
    Pouvez-vous m'aider SVP.

  2. #2
    Membre averti Avatar de Kiouane
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2016
    Messages : 198
    Points : 394
    Points
    394
    Par défaut
    Romain continue sur la même discussion ça évitera de créer plusieurs discussions.
    Sinon je te propose comme suit :
    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
    Sub tri()
    Application.ScreenUpdating = False
     
     
     With Sheets("TRI")
        n = .Range("A" & Rows.Count).End(xlUp).Row
        .Range("A3:E" & n).Sort Key1:=Range("B3:B400"), Order1:=xlDescending, Header:= _
            xlNo, OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom, _
            DataOption1:=xlSortTextAsNumbers
     
    End With
     
    For v = 12 To 408 Step 11
      For j = 1 To 13
        For i = n - 1 To 3 Step -1
     
         If Cells(i, 1).Value = v Then
           For y = 1 To n - i
             If Cells(i + y, 1).Value < v Then
                Application.CutCopyMode = False
                Range(Cells(i, 1),cells(i,5)).Cut
                Cells(i + y + 1, 1).Select
                Selection.Insert Shift:=xlDown
     
     
              Exit For
              End If
            Next
     
         End If
     
      Next
     
     Next
    Next
     
    Application.ScreenUpdating = True
     
    End Sub

  3. #3
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2015
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2015
    Messages : 72
    Points : 149
    Points
    149
    Par défaut
    J'ai pas vu la différence entre te deux codes mais j'ai peut-être rater un truc.
    Ne faut-il pas simplement remplacer n = 400?

    Au passage si le n est aussi grand je pense que c'est encoreeeeeeeeeeee un soucis de lignes supplémentaires vide qui prennent de la place du temps et servent à rien.

    DeathZarakai.

  4. #4
    Membre averti Avatar de Kiouane
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2016
    Messages : 198
    Points : 394
    Points
    394
    Par défaut
    La différence est sur cette ligne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Cells(i, 1).EntireRow.Cut
    qui devient propre à la plage concernée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range(Cells(i, 1),cells(i,5)).Cut

  5. #5
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2015
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2015
    Messages : 72
    Points : 149
    Points
    149
    Par défaut
    Autant pour moi, j'avais pas vu la différence. Mais j'ai dit j'ai pas vu la différence pas dit qu'il y en avait pas^^
    Par conter je persiste, je pense qu'il utilise des ligne vide bouffe mémoire pour que sa affecte des 100aine de milliers de lignes.

    J'ai calculé sa plage fait 1985 cellules, du coup avec entête etc je dirais 2000 cellules mains 200 000 il y a un soucis.

    DeathZarakai.

  6. #6
    Membre averti Avatar de Kiouane
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2016
    Messages : 198
    Points : 394
    Points
    394
    Par défaut
    Si tu regardes la modification, tu comprendras que la procédure se faisait sur toute la ligne... Ce qui fait autant de traitement.

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 31/08/2014, 17h52
  2. De la rapidité du code
    Par jfloviou dans le forum Contribuez
    Réponses: 233
    Dernier message: 29/05/2009, 02h17
  3. Optimisation code pour gagner en rapidité
    Par polodu84 dans le forum MATLAB
    Réponses: 2
    Dernier message: 05/03/2008, 15h32
  4. requete QBE / requete code : rapidité et index
    Par LostIN dans le forum Requêtes et SQL.
    Réponses: 11
    Dernier message: 05/07/2006, 08h54
  5. [rapidité du code] Mise a jour a partir d'un TQuery.
    Par goethe dans le forum Bases de données
    Réponses: 4
    Dernier message: 27/10/2004, 09h01

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