VBA EXCEL problème de boucle
Résolu
llecarpentier
Messages postés
29
Date d'inscription
Statut
Membre
Dernière intervention
-
Le Pingou Messages postés 12249 Date d'inscription Statut Contributeur Dernière intervention -
Le Pingou Messages postés 12249 Date d'inscription Statut Contributeur Dernière intervention -
A voir également:
- VBA EXCEL problème de boucle
- Liste déroulante excel - Guide
- Word et excel gratuit - Guide
- Déplacer colonne excel - Guide
- Si ou excel - Guide
- Excel compter cellule couleur sans vba - Guide
4 réponses
bonjour
sans tester
te donne la dernière ligne non vide dans la colonne A
et ensuite
sans tester
lig_fin=sheets("stock").cells(cell.rows,count,1).row
te donne la dernière ligne non vide dans la colonne A
et ensuite
With Sheets("synthese") .Range("G2:G" & lig_fin).Value = Workshee..... m^me punition pour les autres range
Je te remercie pour ta réponse.
Si j'ai bien compris mon code doit ressembler à ça:
Sub RecupPhysicalAvailable()
lig_fin = Sheets("stock").Cells(cell.Rows, Count, 1).Row
With Sheets("synthese")
.Range("G2:G" & lig_fin).Value = WorksheetFunction.VLookup(.Range("B2:B65236").Value, Sheets("stock").Range("A:C"), 3, True)
End With
End Sub
si c'est le cas quand je le check une boite de dialogue s'ouvre disant "erreur d'execution 424 objet requis".
Si j'ai bien compris mon code doit ressembler à ça:
Sub RecupPhysicalAvailable()
lig_fin = Sheets("stock").Cells(cell.Rows, Count, 1).Row
With Sheets("synthese")
.Range("G2:G" & lig_fin).Value = WorksheetFunction.VLookup(.Range("B2:B65236").Value, Sheets("stock").Range("A:C"), 3, True)
End With
End Sub
si c'est le cas quand je le check une boite de dialogue s'ouvre disant "erreur d'execution 424 objet requis".
excuse moi
faute de frappe
lig_fin = Sheets("stock").Cells(cells.Rows, Count, 1).Row
mais pourquoi utiliser toutes les lignes
Range("B2:B65236")
et pourquoi utiliser un vlookup ?
j'aurais tendance a écrire (non testé sur maquette)
ps: Excusez moi je n'avais pas dit bonjour
faute de frappe
lig_fin = Sheets("stock").Cells(cells.Rows, Count, 1).Row
mais pourquoi utiliser toutes les lignes
Range("B2:B65236")
et pourquoi utiliser un vlookup ?
j'aurais tendance a écrire (non testé sur maquette)
lig_fin = Sheets("stock").Cells(cells.Rows, Count, 1).end(xlup).row sheets("synthese").range(G2:G" & lig_fin)=Sheets("stock").range("C2:c" & lig_fin).value
ps: Excusez moi je n'avais pas dit bonjour
Comme je n'ai pas totalement compris le principe, je l'ai tenté aussi de la manière suivante.
Sub RecupPhysicalAvailable()
lig_fin = Sheets("stock").Cells(cell.Rows, Count, 1).Row
With Sheets("synthese")
.Range("G2:G" & lig_fin).Value = WorksheetFunction.VLookup(.Range("B2:B" & lig_fin).Value, Sheets("stock").Range("A:C" & lig_fin), 3, True)
End With
End Sub
Malheureusement le message d'erreur est le même.
Sub RecupPhysicalAvailable()
lig_fin = Sheets("stock").Cells(cell.Rows, Count, 1).Row
With Sheets("synthese")
.Range("G2:G" & lig_fin).Value = WorksheetFunction.VLookup(.Range("B2:B" & lig_fin).Value, Sheets("stock").Range("A:C" & lig_fin), 3, True)
End With
End Sub
Malheureusement le message d'erreur est le même.
Je suis désolé mais ça ne marche pas. Il m'écris erreur de compilation et surligne le « : » entre G2 et G.
Cependant je ne sais pas si j'ai été tout à fait clair sur mon problème.
Mettons que le tableau stock soit designé de la manière suivante
Numéro d'article/ groupe d'article/ Stock dispo
1000045/ surgelé/ 149
1000789/ frais/ 54
... ... / ...
1145852 / conserve/ 810
Le nombre de ligne varie chaque fois que j'actualise cette feuille.
Le tableau synthèse regroupe des éléments venant en partie de la feuille « stock » et se profile ainsi :
Groupe d'article/Numéro d'article/Quantité requise/nom d'article/statut/référence
Surgelé/1000045/121/glace vanille/en attente/destock
Frais/1000789/58/tomate/en attente/destock
.../.../.../.../.../...
Conserve/1145852/723/en attente/destock
« En attente » et « destock » sont des constantes. C'est dans une colonne à coté de référence que je souhaite placer « stock dispo ».
L'ordre et le nombre de numéro d'article ne sont pas les mêmes entre les deux feuilles. C'est la raison pour laquelle j'utilise un VLookup. En gros je veux que G1 « synthese » = C ? « stock » quand B1 « synthese »= B ? « stock ».
Or, je souhaite que ma fonction de recherche soit entièrement automatique et qu'elle dépende de la dimension de ma feuille « synthèse » qui varie selon la feuille stock.
Jusqu'à maintenant je définie de grande plage même quand mes cellule source sont vide ce qui crée des erreur dans ma colonne G de type #N/A.
Je ne sais pas si j'ai été clair. C'est déjà pas simple pour moi...
Cependant je ne sais pas si j'ai été tout à fait clair sur mon problème.
Mettons que le tableau stock soit designé de la manière suivante
Numéro d'article/ groupe d'article/ Stock dispo
1000045/ surgelé/ 149
1000789/ frais/ 54
... ... / ...
1145852 / conserve/ 810
Le nombre de ligne varie chaque fois que j'actualise cette feuille.
Le tableau synthèse regroupe des éléments venant en partie de la feuille « stock » et se profile ainsi :
Groupe d'article/Numéro d'article/Quantité requise/nom d'article/statut/référence
Surgelé/1000045/121/glace vanille/en attente/destock
Frais/1000789/58/tomate/en attente/destock
.../.../.../.../.../...
Conserve/1145852/723/en attente/destock
« En attente » et « destock » sont des constantes. C'est dans une colonne à coté de référence que je souhaite placer « stock dispo ».
L'ordre et le nombre de numéro d'article ne sont pas les mêmes entre les deux feuilles. C'est la raison pour laquelle j'utilise un VLookup. En gros je veux que G1 « synthese » = C ? « stock » quand B1 « synthese »= B ? « stock ».
Or, je souhaite que ma fonction de recherche soit entièrement automatique et qu'elle dépende de la dimension de ma feuille « synthèse » qui varie selon la feuille stock.
Jusqu'à maintenant je définie de grande plage même quand mes cellule source sont vide ce qui crée des erreur dans ma colonne G de type #N/A.
Je ne sais pas si j'ai été clair. C'est déjà pas simple pour moi...