Procédure avec Find
Résolu
cowboy56
Messages postés
19
Date d'inscription
Statut
Membre
Dernière intervention
-
cowboy56 Messages postés 19 Date d'inscription Statut Membre Dernière intervention -
cowboy56 Messages postés 19 Date d'inscription Statut Membre Dernière intervention -
A voir également:
- Procédure avec Find
- Find and mount - Télécharger - Récupération de données
- Ava find - Télécharger - Divers Utilitaires
- Find junk files - Télécharger - Nettoyage
- Le point d'entrée de procédure eventsetinformation est introuvable advapi32.dll - Forum Windows
- Find ctime ✓ - Forum Shell
14 réponses
Bonjour Luky Luke
"papa" se trouve t il sur une seule colonne (colonne C par ex) ou n'importe où dans C6:G23 ?
feuille de recherche: feuille1 ?
feuille de restitution: feuille2 ? cellule de départ (A2 ?) de la restitution des lignes avec "papa" ?
-----
Signé Joe Dalton
"papa" se trouve t il sur une seule colonne (colonne C par ex) ou n'importe où dans C6:G23 ?
feuille de recherche: feuille1 ?
feuille de restitution: feuille2 ? cellule de départ (A2 ?) de la restitution des lignes avec "papa" ?
-----
Signé Joe Dalton
Bonjour Michel,
Merci pour la réponse rapide, je crois que je me suis emballé un p'tit peu, je vais essayer de vous donner tous les éléments.
- j'ai un classeur 1\feuille 1\tableau 1 avec dans la colonne B, les noms (env 30). les noms ne se suivent pas ligne par ligne (ex : papa en B5, mimi en B7, momo en B10, etc...
Sur la ligne de chaque nom, environ 60 cellules à copier (ex: pour papa, C5, D5, E5 etc....)
- j'ai un autre classeur 2\feuille 1\tableau 1 avec la même chose mais des noms différent du premier tableau et avec l'ordre des noms qui change, également, en face, 60 cellules à copier
-Je veux coller chaque lot de cellule copié par nom dans un troisième classeur 3 \feuille 1\tableau 1 en face du même nom. Dans ce dernier tableau, les noms sont dans l'ordre alphabétique et aussi décalés (B5, B7, B9, etc...)
Dans l'idéal : la procédure se trouve sur mon troisième tableau
- j'ouvre classeur 1 \ feuille 1 (tableau 1)
- j'ouvre classeur 2 \ feuille 1 (tableau 1)
- Je copie les données du classeur 1 et je les colle dans le classeur 3 \ feuille 1 tableau 1
- Je copie les données du classeur 2 et je les colle dans le classeur 3 \ feuille 1 tableau 1
- je fais la même chose pour les six onglets suivants
- je ferme sans enregistrer le tableau 1
- je ferme sans enregistrer le tableau 2
J'espère avoir bien expliqué mon problème, j'ai quand même l'impression de vouloir créer une usine à gaz.
Merci pour votre soutien et du temps que vous m'accorder.
Cowboy56
Merci pour la réponse rapide, je crois que je me suis emballé un p'tit peu, je vais essayer de vous donner tous les éléments.
- j'ai un classeur 1\feuille 1\tableau 1 avec dans la colonne B, les noms (env 30). les noms ne se suivent pas ligne par ligne (ex : papa en B5, mimi en B7, momo en B10, etc...
Sur la ligne de chaque nom, environ 60 cellules à copier (ex: pour papa, C5, D5, E5 etc....)
- j'ai un autre classeur 2\feuille 1\tableau 1 avec la même chose mais des noms différent du premier tableau et avec l'ordre des noms qui change, également, en face, 60 cellules à copier
-Je veux coller chaque lot de cellule copié par nom dans un troisième classeur 3 \feuille 1\tableau 1 en face du même nom. Dans ce dernier tableau, les noms sont dans l'ordre alphabétique et aussi décalés (B5, B7, B9, etc...)
Dans l'idéal : la procédure se trouve sur mon troisième tableau
- j'ouvre classeur 1 \ feuille 1 (tableau 1)
- j'ouvre classeur 2 \ feuille 1 (tableau 1)
- Je copie les données du classeur 1 et je les colle dans le classeur 3 \ feuille 1 tableau 1
- Je copie les données du classeur 2 et je les colle dans le classeur 3 \ feuille 1 tableau 1
- je fais la même chose pour les six onglets suivants
- je ferme sans enregistrer le tableau 1
- je ferme sans enregistrer le tableau 2
J'espère avoir bien expliqué mon problème, j'ai quand même l'impression de vouloir créer une usine à gaz.
Merci pour votre soutien et du temps que vous m'accorder.
Cowboy56
bonjour,
pour s'en sortir:
mettre un extrait de tes 3 classeurs (et non un exemple vite fait mal fait) zippés ensemble sans données confidentielles en pièce jointe sur
https://www.cjoint.com/
puis copier l'adresse du lien et la coller dans le message de réponse
pour s'en sortir:
mettre un extrait de tes 3 classeurs (et non un exemple vite fait mal fait) zippés ensemble sans données confidentielles en pièce jointe sur
https://www.cjoint.com/
puis copier l'adresse du lien et la coller dans le message de réponse
Bonjour,
Oui l'ébauche marche bien mais je ne travaille que sur 2 tableaux, il faut étendre sur trois et ensuite sur les onglets, la tache me semble insurmontable.
Merci
Oui l'ébauche marche bien mais je ne travaille que sur 2 tableaux, il faut étendre sur trois et ensuite sur les onglets, la tache me semble insurmontable.
Merci
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Bonjour cowboy56,
Salut Michel,
Excusez l'incruste, je ne fais que passer.
Juste pour signaler à cowboy la fonction personnalisée FindAll qui retourne une variable tableau contenant les lignes ou l'on trouve le mot cherché...
Bonne continuation
Salut Michel,
Excusez l'incruste, je ne fais que passer.
Juste pour signaler à cowboy la fonction personnalisée FindAll qui retourne une variable tableau contenant les lignes ou l'on trouve le mot cherché...
Bonne continuation
Bonjour Michel,
Je ne suis pas sûr d'avoir bien procéder mais voilà le lien pour les fichiers.
https://www.cjoint.com/?3HgoNBfAGX1
J'espère que ça marchera.
A bientôt
Cowboy56
Je ne suis pas sûr d'avoir bien procéder mais voilà le lien pour les fichiers.
https://www.cjoint.com/?3HgoNBfAGX1
J'espère que ça marchera.
A bientôt
Cowboy56
J'ai les trois fichiers.
Pas de souci.
Que veux tu faire exactement?
Si j'ai bien compris...
Dans le classeur "Planning général" tu as une liste de noms en colonne B (avec ou sans vides???).
Tu veux aller chercher, dans toutes les feuilles des deux autres classeurs, toutes les lignes contenant le nom en colonne B et rapatrier vers Planning général toutes ces lignes. Les mettre l'une sous l'autre???
C'est quelque chose comme ça?
Pas de souci.
Que veux tu faire exactement?
Si j'ai bien compris...
Dans le classeur "Planning général" tu as une liste de noms en colonne B (avec ou sans vides???).
Tu veux aller chercher, dans toutes les feuilles des deux autres classeurs, toutes les lignes contenant le nom en colonne B et rapatrier vers Planning général toutes ces lignes. Les mettre l'une sous l'autre???
C'est quelque chose comme ça?
Bonjour pijaku,
Effectivement, je veux rapatrier les données des deux plannings, Exploitation et Maintenance vers le Planning General mais surtout par nom.
L'ordre des noms dans les plannings Exploitation et Maintenance peuvent bouger.
Cowboy56
Effectivement, je veux rapatrier les données des deux plannings, Exploitation et Maintenance vers le Planning General mais surtout par nom.
L'ordre des noms dans les plannings Exploitation et Maintenance peuvent bouger.
Cowboy56
pijaku,
Quelques explications
Chaque classeur comportera 18 onglets, les mêmes pour les trois classeurs à savoir, les mois sur 1 an et demi
Chaque onglet comportera un tableau, toujours le même pour chaque classeur
les tableaux du classeur "Planning Général" comportera tous les noms, ceux des tableaux Exploitation et maintenance, environ 30
Les tableaux Exploitation et Maintenance comporteront chacun environ 15 noms
les données du mois de janvier des classeurs Exploitation et Maintenance doivent être rapatriées dans l'onglet janvier du classeur Général et ainsi de suite.
Merci pour l'effort mais je ne veux pas abuser, ma mauvaise connaissance du VBA me conduit peut-être à penser à des choses impossibles. Si l'usine à gaz est trop complexe, il y a peut-être moyen de simplifier, je suis ouvert.
Merci encore
Quelques explications
Chaque classeur comportera 18 onglets, les mêmes pour les trois classeurs à savoir, les mois sur 1 an et demi
Chaque onglet comportera un tableau, toujours le même pour chaque classeur
les tableaux du classeur "Planning Général" comportera tous les noms, ceux des tableaux Exploitation et maintenance, environ 30
Les tableaux Exploitation et Maintenance comporteront chacun environ 15 noms
les données du mois de janvier des classeurs Exploitation et Maintenance doivent être rapatriées dans l'onglet janvier du classeur Général et ainsi de suite.
Merci pour l'effort mais je ne veux pas abuser, ma mauvaise connaissance du VBA me conduit peut-être à penser à des choses impossibles. Si l'usine à gaz est trop complexe, il y a peut-être moyen de simplifier, je suis ouvert.
Merci encore
Salut,
Tes explications devraient suffire.
Une macro semble être le meilleur moyen de ne pas faire d'usine à gaz.
Par contre, pour fonctionner, il faudra que les 3 fichiers soient ouverts (sur le même pc, ça semble évident mais je préfères le dire...). Pour travailler avec des fichiers fermés (c'est faisable également), il me faudrait d'autres informations (répertoire d'accès etc...).
Cela te convient-il comme cela?
ps : tu n'abuses pas du tout. Si tu voyais certaines demandes pleines d'imprécisions et d'impolitesses.....
Tes explications devraient suffire.
Une macro semble être le meilleur moyen de ne pas faire d'usine à gaz.
Par contre, pour fonctionner, il faudra que les 3 fichiers soient ouverts (sur le même pc, ça semble évident mais je préfères le dire...). Pour travailler avec des fichiers fermés (c'est faisable également), il me faudrait d'autres informations (répertoire d'accès etc...).
Cela te convient-il comme cela?
ps : tu n'abuses pas du tout. Si tu voyais certaines demandes pleines d'imprécisions et d'impolitesses.....
Voilà un premier jet.
Sans Find...
Attention, pour le tester, tu dis ABSOLUMENT travailler sur des copies de tes fichiers. En effet, les données des feuilles du Planning Général sont effacées avant importation.
Voici la macro (à placer dans un module du planning général), testes la et reviens me dire tout ce qui ne convient pas.
Sans Find...
Attention, pour le tester, tu dis ABSOLUMENT travailler sur des copies de tes fichiers. En effet, les données des feuilles du Planning Général sont effacées avant importation.
Voici la macro (à placer dans un module du planning général), testes la et reviens me dire tout ce qui ne convient pas.
Sub Importer()
'Variables utiles à la boucle
Dim Wbk As Workbook 'classeurs
Dim Wsh As Worksheet 'feuilles
'Variables utiles pour déterminer la plage
Dim Dlig As Long 'dernière ligne remplie
'Variables tableau pour le stockage et la restitution des données
Dim Tb(), Indic As Long
'variables numériques pour les boucles sur la variable tableau
Dim i As Long, j As Long
'Effacement des données précédemment recueillies !!!!!!!!!!!!!!!!!!!!!!!
For Each Wsh In ThisWorkbook.Worksheets
Wsh.Cells.Clear
Next Wsh
'Pour tous les classeurs ouverts dans l'application
For Each Wbk In Application.Workbooks
'Si le classeur n'est pas le planning général (celui qui contient la macro)
If Wbk.Name <> ThisWorkbook.Name Then
'Pour toutes les feuilles de ce classeur (différent de ThisWorkbook)
For Each Wsh In Wbk.Worksheets
'Dans la feuille en cours
With Wsh
'dernière ligne remplie de la colonne B
Dlig = .Range("B" & Rows.Count).End(xlUp).Row
'stockage des données contenues dans les 60 colonnes et x lignes de cette plage
'Si cellule en B non vide
For i = 1 To Wsh.Range("B5:B" & Dlig).Cells.Count
If Wsh.Cells(i + 4, 2) <> "" Then
Indic = Indic + 1
ReDim Preserve Tb(1 To 60, 1 To Indic)
For j = 1 To 60
Tb(j, Indic) = Wsh.Cells(i + 4, j + 1)
Next j
End If
Next i
End With
'Restitution des données dans la feuille du même nom
With ThisWorkbook.Worksheets(Wsh.Name)
Dlig = .Range("B" & Rows.Count).End(xlUp).Row + 1
If Dlig = 2 Then Dlig = 5
.Range("B" & Dlig).Resize(UBound(Tb, 2), UBound(Tb, 1)) = Application.Transpose(Tb)
End With
'Effacement de la variable tableau
Erase Tb
Indic = 0
Next Wsh
End If
Next Wbk
End Sub
Pijaku,
Me revoilà, j'ai fait le test, ça ne fonctionne pas et je ne sais pas pourquoi, j'ai bien ouvert les trois fichiers comme tu l'a dis pourtant.
Je t'envoie l'erreur que j'obtiens, entre les deux captures d'écran, il y a juste une pression sur F8.
https://www.cjoint.com/?3HhtMMuulFL
Regarde ce que tu peux faire et tiens moi au courant.
Merci
Me revoilà, j'ai fait le test, ça ne fonctionne pas et je ne sais pas pourquoi, j'ai bien ouvert les trois fichiers comme tu l'a dis pourtant.
Je t'envoie l'erreur que j'obtiens, entre les deux captures d'écran, il y a juste une pression sur F8.
https://www.cjoint.com/?3HhtMMuulFL
Regarde ce que tu peux faire et tiens moi au courant.
Merci
Salut,
Ok, compris, ce soir je passe l'ensemble des fichiers et onglets à la vérification et je te tiens au courant
Bonne journée
Ok, compris, ce soir je passe l'ensemble des fichiers et onglets à la vérification et je te tiens au courant
Bonne journée
Bonsoir pijaku
J'ai revu mes fichiers, vérifier mes onglets ainsi que les noms, rien à faire, la procédure ne fonctionne pas. Impossible pour moi de dire pourquoi. De mon coté, j'ai avancé sur ma première procédure et j'ai réussi à trouver une solution qui marche, en fait il faudra deux macros mais ça le fait. il me reste à
1- Gérer les erreurs (absence de noms ou doublon dans l'un des fichiers, problème quelconque sur un des fichiers, etc...)
2- Gérer le passage d'onglet en onglet (Je préférerais travaillé en +1 plutôt qu'avec les noms des onglets)
je veux bien essayer ta macro avec les fichiers sur lesquels ça fonctionne, si tu peux me les envoyés.
Merci pour tes efforts
Cowboy56
J'ai revu mes fichiers, vérifier mes onglets ainsi que les noms, rien à faire, la procédure ne fonctionne pas. Impossible pour moi de dire pourquoi. De mon coté, j'ai avancé sur ma première procédure et j'ai réussi à trouver une solution qui marche, en fait il faudra deux macros mais ça le fait. il me reste à
1- Gérer les erreurs (absence de noms ou doublon dans l'un des fichiers, problème quelconque sur un des fichiers, etc...)
2- Gérer le passage d'onglet en onglet (Je préférerais travaillé en +1 plutôt qu'avec les noms des onglets)
je veux bien essayer ta macro avec les fichiers sur lesquels ça fonctionne, si tu peux me les envoyés.
Merci pour tes efforts
Cowboy56
Merci à tous ceux qui se sont penché sur mon problème, je mets le résultat de ce que j'ai trouvé, il y a certainement des erreurs dans les commentaires mais ça fonctionne, je vais m'en m'en contenter. j'ai remarqué que certaine procédure ne marchait pas chez moi, cela vient de la version office qui est très ancienne. je vais évoluer et reprendrai les macros ensuite.
Merci encore à tous.
Merci encore à tous.
Sub Cherche() 'code pour éviter de voir le défilement de la macro Application.ScreenUpdating = False 'code pour éviter les alertes de vidange du presse-papier Application.DisplayAlerts = False 'code pour effacer les données de toutes les feuilles Dim w As Object For Each w In Worksheets Sheets(w.Name).[C5:BJ35].ClearContents Next 'définition de la variable f Dim f As Variant 'f = la feuille active f = ActiveSheet.Index 'calcul du nombre de feuille total du fichier totalSheets = ActiveWorkbook.Sheets.Count 'f = feuille courante curentSheet = f 'Set plageC = Application.ActiveWorkbook.ActiveSheet.UsedRange.Columns("A").Cells 'action si la feuille courante est plus petite que le total des feuilles Do Until curentSheet > totalSheets 'renommer la feuille active f = curentSheet 'selectionner le classeur et la feuille courante ActiveWorkbook.Sheets(curentSheet).Select 'avec cette selection With Selection 'Variables pour trouver les plages de traitement Dim Trouve As Range, PlageDeRecherche As Range 'Variables pour les noms à traiter Dim Valeur_Cherchee As String, AdresseTrouvee As String Dim i As Range 'Chercher dans la base de noms For Each i In Range("BK1:BK6").Cells 'numeroter les noms Valeur_Cherchee = i.Value 'ouvrir le classeur exploitation ChDir "G:\2 - EXPLOITATION" Workbooks.Open Filename:="G:\2 - EXPLOITATION\Planning Exploitation.xls" Sheets(f).Select 'Selectionner la cellule A1 Range("A1").Activate 'Dans la plage B5:B35 Set PlageDeRecherche = Range("B5:B35") 'Chercher le nom et l'appeler trouve Set Trouve = PlageDeRecherche.Cells.Find(What:=Valeur_Cherchee, LookAt:=xlWhole) 'S'il n'existe pas If Trouve Is Nothing Then 'Panneau MsgBox Valeur_Cherchee & " n'est pas présent dans l'onglet " & (f) & " du fichier EXPLOITATION" 'Sortir e la procedure Exit Sub 'sinon Else ' l'appeler Adressetrouvee AdresseTrouvee = Trouve.Address 'fin du si End If 'selectionner la cellule Range(AdresseTrouvee).Activate 'etendre la selection Selection.Resize(Selection.Rows.Count + 0, Selection.Columns.Count + 60).Select 'copier Selection.Copy 'activer le planning general Windows("Planning General.xls").Activate 'Chercher le meme nom que celui copier Range("B5:B35").Find(What:=Valeur_Cherchee, LookIn:=xlValues, LookAt:=xlWhole).Activate 'coller ActiveSheet.Paste 'fin de i Next i End With 'fin du traitement de la feuille curentSheet = curentSheet + 1 'feuille suivante Loop 'Fi 'activer la cellule A1 Range("A1").Activate 'Next f 'Fermer le fichier exploitation Windows("Planning Exploitation.xls").Close 'Desactiver la plage de rechche Set PlageDeRecherche = Nothing 'Desactiver la recherche de "trouve" Set Trouve = Nothing 'Réactiver les alertes Application.DisplayAlerts = True 'Reactiver le défilement de la macro Application.ScreenUpdating = True 'Fin de la macro End Sub