A voir également:
- Aide sur une macro excel
- Telecharger macro convertir chiffre en lettre excel - Télécharger - Tableur
- Liste déroulante excel - Guide
- Calculer une moyenne sur excel - Guide
- Déplacer une colonne excel - Guide
- Si et excel - Guide
3 réponses
Mytå
Messages postés
2973
Date d'inscription
mardi 20 janvier 2009
Statut
Contributeur
Dernière intervention
20 décembre 2016
950
Modifié par Mytå le 14/09/2012 à 00:33
Modifié par Mytå le 14/09/2012 à 00:33
Salut le forum
Essaye comme ceci
Mytå
Quelle prétention de prétendre que l'informatique est récente
Adam et Eve avaient déjà un Apple ! [MsProject 2003(FR), Excel 2003-2007(FR)]
Essaye comme ceci
Sub colis1() With Range("H53") If .Value < 1 Or .Value > 40 Then Exit Sub Rows("79:238").EntireRow.Hidden = True Rows("79:" & 82 + (.Value - 1) * 4).EntireRow.Hidden = False .Offset(0, 3).Select End With End Sub
Mytå
Quelle prétention de prétendre que l'informatique est récente
Adam et Eve avaient déjà un Apple ! [MsProject 2003(FR), Excel 2003-2007(FR)]
Merci Myta,
La macro est super à la seul précison que si h53 = 0 toutes les lignes doivent être closes.
Pourrais tu juste me préciser comment compiler cela?
Merci beaucoup vraiment ;)
La macro est super à la seul précison que si h53 = 0 toutes les lignes doivent être closes.
Pourrais tu juste me préciser comment compiler cela?
Merci beaucoup vraiment ;)
Mytå
Messages postés
2973
Date d'inscription
mardi 20 janvier 2009
Statut
Contributeur
Dernière intervention
20 décembre 2016
950
14 sept. 2012 à 08:09
14 sept. 2012 à 08:09
Re le forum
Il suffit d'inverser deux lignes
Mytå
Il suffit d'inverser deux lignes
Sub colis1() With Range("H53") Rows("79:238").EntireRow.Hidden = True If .Value < 1 Or .Value > 40 Then Exit Sub Rows("79:" & 82 + (.Value - 1) * 4).EntireRow.Hidden = False .Offset(0, 3).Select End With End Sub
Mytå
Bonjour à tous,
Vraiment merci beaucoup pour ton retour.
Alors voici la macro terminée (valable pour l'ensemble du fichier excel)
elle ne fonctionne pas parfaitement, est elle trop grosse ou y a t il des lignes qui se contredisent?
(lorsque je met 0 elle ne se ferme pas ou la macro ne répond pas)
Merci vraiment ;D
Sub ok()
If Range("f51") <> "ERREUR" Then
With Range("g58")
Rows("399:562").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("399:" & 402 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
With Range("g57")
Rows("239:398").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("239:" & 242 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
With Range("g59")
Rows("563:722").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("563:" & 566 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
If Range("b52") = vrai Then
Rows("75:78").EntireRow.Hidden = True
ElseIf Range("b52") = faux Then
Rows("75:78").EntireRow.Hidden = False
End If
If Range("b58") = "x" Then
Rows("883:886").EntireRow.Hidden = True
ElseIf Range("b58") = "xx" Then
Rows("883:886").EntireRow.Hidden = False
End If
With Range("g62")
Rows("887:1046").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("887:" & 890 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
With Range("g56")
Rows("79:238").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("79:" & 82 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
With Range("g60")
Rows("723:882").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("723:" & 726 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
End If
Range("h55").Select
End Sub
Vraiment merci beaucoup pour ton retour.
Alors voici la macro terminée (valable pour l'ensemble du fichier excel)
elle ne fonctionne pas parfaitement, est elle trop grosse ou y a t il des lignes qui se contredisent?
(lorsque je met 0 elle ne se ferme pas ou la macro ne répond pas)
Merci vraiment ;D
Sub ok()
If Range("f51") <> "ERREUR" Then
With Range("g58")
Rows("399:562").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("399:" & 402 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
With Range("g57")
Rows("239:398").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("239:" & 242 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
With Range("g59")
Rows("563:722").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("563:" & 566 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
If Range("b52") = vrai Then
Rows("75:78").EntireRow.Hidden = True
ElseIf Range("b52") = faux Then
Rows("75:78").EntireRow.Hidden = False
End If
If Range("b58") = "x" Then
Rows("883:886").EntireRow.Hidden = True
ElseIf Range("b58") = "xx" Then
Rows("883:886").EntireRow.Hidden = False
End If
With Range("g62")
Rows("887:1046").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("887:" & 890 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
With Range("g56")
Rows("79:238").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("79:" & 82 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
With Range("g60")
Rows("723:882").EntireRow.Hidden = True
If .Value < 1 Or .Value > 40 Then Exit Sub
Rows("723:" & 726 + (.Value - 1) * 4).EntireRow.Hidden = False
End With
End If
Range("h55").Select
End Sub