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 :

Freeze lors de cette fonction


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2009
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2009
    Messages : 168
    Par défaut Freeze lors de cette fonction
    Bonjours ,
    lorsque je lance cette fonction mon application freeze ( ne répond plus ) je suis obliger de fermer par la suite :/

    Voici le 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
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
     
    Sub sauver_facture()
     
    Dim Nom_save As String
    '--Variables de recherche ------------------------------------------------------
    Dim objRange As Range, PlageRed As Range, objCell As Range, PlageResult As Range
    Dim RechVirtuel As Range
    Dim nbFeuille As Integer
     
    Nom_save = FormSave.NomFichier.Value
     
     
     
    Cells.Select
    Selection.Copy
    Workbooks.Add
    Cells.Select
    Selection.PasteSpecial Paste:=xlPasteAll, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
    Selection.PasteSpecial Paste:=xlPasteAllUsingSourceTheme, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
    Selection.PasteSpecial Paste:=xlPasteColumnWidths, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
     
    'réduction de la plage
     
    For Each objRange In ActiveWorkbook.Worksheets(1).Columns
        If IsNull(objRange.Interior.ColorIndex) Then
            If PlageRed Is Nothing Then
                Set PlageRed = objRange
            Else
                Set PlageRed = Application.Union(objRange, PlageRed)
            End If
        End If
    Next
     
    'travail en ligne
    For Each objRange In ActiveWorkbook.Worksheets(1).Rows
        If IsNull(objRange.Interior.ColorIndex) Then
            For Each objCell In objRange.Cells
                If objCell.Interior.ColorIndex = 15 Then
                    '--Traitement a l'interieur de cette boucle-----------------------
                    objCell.Value = ""
                    With objCell.Interior
                        .Pattern = xlNone
                        .TintAndShade = 0
                        .PatternTintAndShade = 0
                    End With
                    objCell.Offset(0, 1).Value = ""
                    '--Fin Traitement-------------------------------------------------
                End If
            Next
        End If
    Next
     
    MsgBox "Hey"
     
    'travail en ligne
    For Each objRange In ActiveWorkbook.Worksheets(1).Rows
        If IsNull(objRange.Interior.ColorIndex) Then
            For Each objCell In objRange.Cells
                If objCell.Interior.Color = RGB(255, 0, 0) Then
                    '--Traitement a l'interieur de cette boucle-----------------------
                    objCell.Value = ""
                    With objCell.Interior
                        .Pattern = xlNone
                        .TintAndShade = 0
                        .PatternTintAndShade = 0
                    End With
                    objCell.Offset(0, 1).Value = ""
                    '--Fin Traitement-------------------------------------------------
                End If
            Next
        End If
    Next
     
    ActiveWorkbook.SaveAs Filename:=Repertoire_save & "\" & Nom_save & ".xls", FileFormat _
            :=xlNormal, Password:="", WriteResPassword:="", ReadOnlyRecommended:= _
            False, CreateBackup:=False
     
    End Sub
    Le but est de copier toute la feuille (ThisWordBook.WorkSheet(1)) vers un autre workbook ( pour supprimer la macro en gros ) et de traiter le nouveau fichier .
    si je remplace ActiveWorkBook par ThisWordBook ( c'est a dire si je travaille la ou est la macro ) la sa fonctionne mais si je travail sur le nouveau classeur
    sa freeze :s.

    Merci,
    ( ActiveWorkBook )

  2. #2
    Expert confirmé
    Avatar de Didier Gonard
    Homme Profil pro
    Formateur Office et développeur VBA en freelance
    Inscrit en
    Février 2008
    Messages
    2 805
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Formateur Office et développeur VBA en freelance

    Informations forums :
    Inscription : Février 2008
    Messages : 2 805
    Par défaut
    Bonjour,

    Ne serait-il pas plus simple et moins lourd d'exporter ta feuille ( ou de sauvegarder sous un nouveau nom en ayant effacé les non-voulues) et de détruire le code genre :

    Sauvegarder le classeur contenant cette macro, puis supprimer la totalité des procédures.
    La macro "SupprimeTout" est aussi détruite.
    http://silkyroad.developpez.com/VBA/...cEditor/#LIV-D

    codialement,

    Didier

  3. #3
    Membre confirmé
    Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2009
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2009
    Messages : 168
    Par défaut
    Merci de votre réponse mais le but est d'enlever la macro mais aussi et surtout de traiter le WorkBook génère et non pas toucher au ThisWorkBook
    Comment corriger ce probleme de freeze ?

    Merci encore

Discussions similaires

  1. qu'est ce qui va pas dans cette fonction???
    Par access001 dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 18/04/2006, 14h10
  2. [3.2M4] Petits freezes lors de l'autocomplete
    Par Glob dans le forum Eclipse Java
    Réponses: 3
    Dernier message: 28/12/2005, 12h41
  3. Réponses: 1
    Dernier message: 05/12/2005, 09h10
  4. Avertissement lors surchage de fonction
    Par Neilos dans le forum C++Builder
    Réponses: 15
    Dernier message: 09/01/2005, 16h51
  5. Réponses: 5
    Dernier message: 03/12/2004, 11h16

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