Error 1004 VBA avec GEF acomba
Résolu
christ.lenoir
Messages postés
39
Statut
Membre
-
gbinforme Messages postés 15478 Statut Contributeur -
gbinforme Messages postés 15478 Statut Contributeur -
Bonjour,
Je fais une macro pour masquer des lignes. Ma macro marche super bien dans un fichier indépendant. Toutefois, lorsque je tente de le faire dans mon fichier excel GEF, cela me fait error 1004 erreur définie par l'application ou par l'objet. Je ne comprends pas pourquoi ...
Voici ma macro :
Sub Macro1()
' pour afficher les lignes
Cells.Select
Selection.EntireRow.Hidden = False
' Pour masquer les lignes
Dim ligne As Integer
For ligne = 10 To 370
If Cells(ligne, 9) = "M" Then
Rows(ligne & ":" & ligne).EntireRow.Hidden = True
End If
Next
End Sub
Le "M" représente une fonction si pour laquelle chaque M, on doit masquer la ligne
Je travail sur Excel 2010
Merci beaucoup d'avance
Je fais une macro pour masquer des lignes. Ma macro marche super bien dans un fichier indépendant. Toutefois, lorsque je tente de le faire dans mon fichier excel GEF, cela me fait error 1004 erreur définie par l'application ou par l'objet. Je ne comprends pas pourquoi ...
Voici ma macro :
Sub Macro1()
' pour afficher les lignes
Cells.Select
Selection.EntireRow.Hidden = False
' Pour masquer les lignes
Dim ligne As Integer
For ligne = 10 To 370
If Cells(ligne, 9) = "M" Then
Rows(ligne & ":" & ligne).EntireRow.Hidden = True
End If
Next
End Sub
Le "M" représente une fonction si pour laquelle chaque M, on doit masquer la ligne
Je travail sur Excel 2010
Merci beaucoup d'avance
A voir également:
- Error 1004 VBA avec GEF acomba
- L'indice n'appartient pas à la sélection vba - Forum VB / VBA
- Fan error lenovo - Forum Refroidissement
- Vba range avec variable ✓ - Forum VB / VBA
- Cmos checksum error ✓ - Forum Carte-mère/mémoire
- Error 1962 ✓ - Forum PC fixe
7 réponses
christ.lenoir
Messages postés
39
Statut
Membre
C'est comme-ci l'erreur était à chacune des lignes... pourtant dans mon notre excel chacune des lignes fonctionnent très bien .. c'est frustrant !!
Je te propose ce code VBA, qui est plus simple :
Ça devrait mieux marcher pour ton fichier excel GEF ;
et tu devrais l'utiliser aussi pour ton fichier excel
indépendant.
⚠ Si une ligne > 32 767, mettre Dim lig As Long
au lieu de Dim lig As Integer
Sub Macro1()
Dim lig As Integer: Application.ScreenUpdating = False
' affiche toutes les lignes
Rows("1:" & Rows.Count).Hidden = False
' des lignes 10 à 370, masque les lignes où il y a
' un "M" en colonne I
For lig = 10 To 370
If Cells(lig, 9) = "M" Then Rows(lig).Hidden = True
Next lig
End Sub
Ça devrait mieux marcher pour ton fichier excel GEF ;
et tu devrais l'utiliser aussi pour ton fichier excel
indépendant.
⚠ Si une ligne > 32 767, mettre Dim lig As Long
au lieu de Dim lig As Integer
Pour la 1ère étape, as-tu réellement besoin d'afficher toutes les lignes du
classeur (donc de 1 à 1 048 576) ? si oui, inutile de lire la suite ; sinon :
En supposant que pour la 1ère étape d'affichage des lignes tu peux te
contenter de la seule plage des lignes 10 à 370, cette étape peut être
scindée avec la seconde étape de masquage des lignes 10 à 370 qui
contiennent "M" en colonne I ; ce qui donne ce nouveau code VBA :
Sub Macro1()
Dim lig As Integer: Application.ScreenUpdating = False
' pour les lignes 10 à 370, masque celles où il y a
' un "M" en colonne I et affiche les autres
For lig = 10 To 370
Rows(lig).Hidden = Cells(lig, 9) = "M"
Next lig
End Sub
En faisant ainsi, peut-être que ton erreur 1004 ne se produira plus,
du fait que l'affichage des lignes est réalisé pour la seule plage des
lignes 10 à 370 ? (peut-être que les autres lignes ont un contenu
particulier qui provoque cette erreur 1004 ?)
Sinon, tu devrais chercher et indiquer ici à quoi correspond cette
erreur 1004 dans ton GEF excel acomba : libellé exact de l'erreur
et pour quel(s) cas cette erreur se produit.
Merci gérard.
Malheureusement, j'ai encore mon error 1004 erreur définie par l'application ou par l'objet, qui se produit et je ne peux savoir ce que c'est puisque je dois faire ctrl + alt + delete pour fermer le excel complètement...
C'était bien pensé puisqu'effectivement, je n'avais pas besoin d'afficher tous les lignes.
Je continue à essayer toute sorte de chose et peut-être nous y arriverons !!
Merci encore.
Malheureusement, j'ai encore mon error 1004 erreur définie par l'application ou par l'objet, qui se produit et je ne peux savoir ce que c'est puisque je dois faire ctrl + alt + delete pour fermer le excel complètement...
C'était bien pensé puisqu'effectivement, je n'avais pas besoin d'afficher tous les lignes.
Je continue à essayer toute sorte de chose et peut-être nous y arriverons !!
Merci encore.
Je ne connais pas GEF Excel acomba, mais je viens de penser que l'instruction
Application.ScreenUpdating = False doit être une instruction spécifique d'Excel,
donc elle ne doit pas être comprise par GEF Excel ! si oui, ce serait donc elle
qui provoque l'erreur 1004 ; or tu peux la supprimer sans problème, et je crois
que ça pourra marcher ainsi :
Sub Macro1()
Dim lig As Integer
' pour les lignes 10 à 370, masque celles où il y a
' un "M" en colonne I et affiche les autres
For lig = 10 To 370
Rows(lig).Hidden = Cells(lig, 9) = "M"
Next lig
End Sub
En fait, dans Excel, Application.ScreenUpdating = False sert seulement
à geler la mise à jour de l'écran pendant l'exécution de la macro, ce qui
en accélère l'exécution ; et Application est l'objet Excel lui-même, alors
que ton application est GEF acomba (Générateur d'États Financiers).
Bonjour,
mettre un simple filtre auto pour masquer tes "M" n'est pas suffisant ?
C'est prévu pour...
eric
En essayant continuellement, on finit par réussir.
Donc plus ça rate, plus on a de chances que ça marche.(les Shadoks)
En plus du merci (si si, ça se fait !!!), penser à mettre en résolu. Merci
mettre un simple filtre auto pour masquer tes "M" n'est pas suffisant ?
C'est prévu pour...
eric
En essayant continuellement, on finit par réussir.
Donc plus ça rate, plus on a de chances que ça marche.(les Shadoks)
En plus du merci (si si, ça se fait !!!), penser à mettre en résolu. Merci
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Bonjour à tous,
Je ne connais non plus ton excel GEF mais je pense que la macro ne sais pas où elle se trouve. Vba excel fonctionne a priori par défaut sur la feuille active mais il me semble que tu pourrais essayer de le préciser ainsi avec la macro de gérard.
Je ne connais non plus ton excel GEF mais je pense que la macro ne sais pas où elle se trouve. Vba excel fonctionne a priori par défaut sur la feuille active mais il me semble que tu pourrais essayer de le préciser ainsi avec la macro de gérard.
Sub Macro1()
Dim lig As Integer: Application.ScreenUpdating = False
With ActiveSheet
' affiche toutes les lignes
.Rows("1:" & .Rows.Count).Hidden = False
' des lignes 10 à 370, masque les lignes où il y a
' un "M" en colonne I
For lig = 10 To 370
If .Cells(lig, 9) = "M" Then .Rows(lig).Hidden = True
Next lig
End With
End Sub
Bonjour christ.lenoir,
l'autre pour masquer les lignes et ça marche super bien.
Si ta macro fonctionne sur autre onglet et pas sur le premier, cela vient sans doute de ta façon de l'appeler qui doit être différente car tu es sur le même classeur et l'erreur 1004 est dûe à l'impossibilité de positionnement sur une plage.
l'autre pour masquer les lignes et ça marche super bien.
Si ta macro fonctionne sur autre onglet et pas sur le premier, cela vient sans doute de ta façon de l'appeler qui doit être différente car tu es sur le même classeur et l'erreur 1004 est dûe à l'impossibilité de positionnement sur une plage.
J'essaie maintenant la simple macro de masquer des lignes sans même les afficher et ça ne fonctionne pas. Par contre, lorsque je garde mon entrer enfoncé jusqu'à ce que le message d'erreur s'en va, j'arrive à mes fins...
Sub Masquer_lignes()
'
' Pour masquer les lignes
Dim ligne As Integer
For ligne = 33 To 70
If Cells(ligne, 9) = "M" Then
Rows(ligne & ":" & ligne).EntireRow.Hidden = True
End If
Next
End Sub
L'erreur ce trouve donc la dedans, mais dans un excel indépendant, ça marche super bien ...
Sub Masquer_lignes()
'
' Pour masquer les lignes
Dim ligne As Integer
For ligne = 33 To 70
If Cells(ligne, 9) = "M" Then
Rows(ligne & ":" & ligne).EntireRow.Hidden = True
End If
Next
End Sub
L'erreur ce trouve donc la dedans, mais dans un excel indépendant, ça marche super bien ...
Pas une solution à ton pb mais peut-être le message d'erreur à valider une fois ou deux seulement :
en attendant de trouver la cause réelle...
eric
Sub Macro1()
Dim lig As Long, pl As Range
For lig = 10 To 370
If Cells(lig, 9) = "M" Then
If pl Is Nothing Then
Set pl = Cells(lig, 9)
Else
Set pl = Union(pl, Cells(lig, 9))
End If
End If
Next lig
' affiche toutes les lignes
Rows.Hidden = False
' des lignes 10 à 370, masque les lignes où il y a
' un "M" en colonne I
If Not pl Is Nothing Then pl.EntireRow.Hidden = True
End Sub
en attendant de trouver la cause réelle...
eric
