[Excel] Problème avec "Cells.Find"
Résolu
NarcisseJulien
Messages postés
27
Date d'inscription
Statut
Membre
Dernière intervention
-
NarcisseJulien Messages postés 27 Date d'inscription Statut Membre Dernière intervention -
NarcisseJulien Messages postés 27 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
Je me retrouve face a un problème avec mon code vba d'une maccro visant à rechercher une valeur dans la colone G de la feuil1 (nommé Janvier), copier les lignes contenant cette valeur (tjr dans la colone G) et ensuite coller ces ligne à partir de la ligne 13 dans une feuil2 (nommée pièces).
La valeur recherchée est donc mise dans la celule D7 de la feuil "pièces"
Je lance la maccro via une userform situé dans cette feuil "pièces"
J'éffectue un comptage de cette valeur dans la colone G de la feuil "janvier"
Je stok cette information dans une variable "k"
Puis je fait une boucle allant de 1 à k pour chercher et copier les lignes contenants la valeur cherchée (dans la colone G) dans ma feuil pièces et ce à partir de la ligne 13.
Mon problème... ça fonctionne pas et j'arrive pas à voir où ça bloque...
Voici le code VBA que j'execute :
Sub Macro1()
'
' Macro1 Macro
' Macro enregistrée le 22/06/2011 par Narcisse Julien
'
j = Range("D7").Value
Sheets("Janvier").Select
k = Application.CountIf(Range("G1").EntireColumn, j)
For i = 1 To k
Cells.Find(What:=j, After:=ActiveRow, LookIn:=xlFormulas, _
LookAt:=xlPart, SearchOrder:=xlByRows, SearchDirection:=xlNext, _
MatchCase:=False, SearchFormat:=False).Activate
Sheets("Pièces").Select
Rows(12 + i & ":" & 12 + i).Select
ActiveSheet.Paste
Next i
End Sub
Si qu'elqu'un a une petite idée de comment m'aider ... Je vous remerice par avance pour votre aimabilité.
Je me retrouve face a un problème avec mon code vba d'une maccro visant à rechercher une valeur dans la colone G de la feuil1 (nommé Janvier), copier les lignes contenant cette valeur (tjr dans la colone G) et ensuite coller ces ligne à partir de la ligne 13 dans une feuil2 (nommée pièces).
La valeur recherchée est donc mise dans la celule D7 de la feuil "pièces"
Je lance la maccro via une userform situé dans cette feuil "pièces"
J'éffectue un comptage de cette valeur dans la colone G de la feuil "janvier"
Je stok cette information dans une variable "k"
Puis je fait une boucle allant de 1 à k pour chercher et copier les lignes contenants la valeur cherchée (dans la colone G) dans ma feuil pièces et ce à partir de la ligne 13.
Mon problème... ça fonctionne pas et j'arrive pas à voir où ça bloque...
Voici le code VBA que j'execute :
Sub Macro1()
'
' Macro1 Macro
' Macro enregistrée le 22/06/2011 par Narcisse Julien
'
j = Range("D7").Value
Sheets("Janvier").Select
k = Application.CountIf(Range("G1").EntireColumn, j)
For i = 1 To k
Cells.Find(What:=j, After:=ActiveRow, LookIn:=xlFormulas, _
LookAt:=xlPart, SearchOrder:=xlByRows, SearchDirection:=xlNext, _
MatchCase:=False, SearchFormat:=False).Activate
Sheets("Pièces").Select
Rows(12 + i & ":" & 12 + i).Select
ActiveSheet.Paste
Next i
End Sub
Si qu'elqu'un a une petite idée de comment m'aider ... Je vous remerice par avance pour votre aimabilité.
A voir également:
- [Excel] Problème avec "Cells.Find"
- Liste déroulante excel - Guide
- Word et excel gratuit - Guide
- Déplacer colonne excel - Guide
- Si ou excel - Guide
- Excel moyenne - Guide
1 réponse
Bonjour
Michel
Sub xxx() With Sheets("janvier") donnee = .Range("D7") nbre = Application.CountIf(.Columns("G"), donnee) If nbre = 0 Then GoTo erreur: Application.ScreenUpdating = False lig = 65536 For cptr = 1 To nbre lig = .Columns("G").Find(donnee, .Cells(lig, "G"), xlValues).Row Sheets("pieces").Rows(12 + cptr) = .Rows(lig).Value Next End With Exit Sub erreur: MsgBox "valeur inconnue", vbCritical End Sub
Michel
Je vais tester tous ça =)
Dans mon test donnee = 4864
Nbre=3
Lig=65536
xlvalues= -4163
cptr=1
[url=http://www.images-host.fr][img]http://www.images-host.fr[/img][/url]
Voici des SS de l'erreur et du code executé...
tu devrais plutôt déposer un fichier exemple sur cijoint.fr et coller ici le lien fourni.
eric
Peux tu m'expliquer pourquoi tu écris
j=range("D7").value
puis
donnee= j
j'avoue que je n'en vois pas du tout l'intérêt et l'utilité, surtout pour écrire en plus une variable à 1 caractère ( i, j, k sont tolérés dans les boucles et encore!...) :o((
J'avais mis l'appel en D7 de sheet "janvier"
donc il fallait écrire
J'ai testé c'est OK
https://www.cjoint.com/?3Fwxq13QHdX