Le 26/11/2021 à 10:35
S
ShadowHitano
- Messages
- 6
- Excel
- 2016 FR
- Inscrit
- 26/11/2021
TELECHARGEMENTS
Plus de 300 applications Excel sont disponibles gratuitement en téléchargement !
- Budget, gestion de comptes
- Gestion commerciale, personnel
- Plannings, calendriers
- Etc.
Voir les applications ...
Bonjour !
Le service RH aimerait utiliser une nouvelle check-list pour l'embauche de collaborateur.
Le fichier contient 4 feuilles, dont une qui est la checklist et les 3 autres sont des feuilles de données.
J'aimerais trouver une solution pour lier les données à la checklist, en faisant apparaitre des checkbox (non cochées) chaque fois que c'est nécessaire (chaque fois qu'il y a une données.
Un premier jet a été réalisé avec des formules, mais cela ne convient pas. Cela ne prend par en charge l'affichage dynamique des checkbox. De plus, tout est pris en compte, et donc, on se retrouve avec des lignes vides pas jolies jolies.
L'idée serait de faire en sorte que, par exemple pour la partie demande de matériel, il ne s'affiche que les matériels qui sont remplis comme "oui" en fonction du métier, et d'y associer une checkbox à chaque fois.
Je pense qu'il faudrait passer par une déclaration de tableau via VBA pour ne récupérer que les combo métier/matériel qui sont "oui", mais j'ai vraiment du mal à maitriser la notion de tableau en VBA.
Quand aux cases à cocher, j'ai un code qui me permet de créer une case sur chaque ligne de la sélection, je pense réussir à l'adapter.
Merci de m'avoir lu, et merci d'avance pour la peine que vous prendrez à me répondre.
73nouvelle-embauche-anonyme.xlsx
Le 26/11/2021 à 14:00
y
yal_excel
- Messages
- 1'033
- Votes
- 287
- Excel
- PC 2010 Fr
- Inscrit
- 11/05/2021
Bonjour
Une proposition VBA
91nouvelle-embauche-anonyme-v1.xlsm
Il te reste à refaire tes cases à cocher
"Quand aux cases à cocher, j'ai un code qui me permet de créer une case sur chaque ligne de la sélection"
Si tu pouvais partager ce code, ça m'intéresse
Cordialement
Le 26/11/2021 à 16:49
S
ShadowHitano
- Messages
- 6
- Excel
- 2016 FR
- Inscrit
- 26/11/2021
Hello Yal !
Merci pour ce retour. J'ai essayé de comprendre ton code, mais vraiment les tableaux, je pige que dalle.
Voici une nouvelle version du fichier, avec pas mal de modification d'ordre esthétique, ce qui met un peu le bazar.
J'ai ajouter le métier 20 avec l'intégralité des données, pour visualiser la place que cela prend.
Les infos, ne vont plus au bon endroit, pourrais-tu jeter un œil s'il te plait?
J'ai mis un bout de code pour les case a cocher. Pour limiter le poids du fichier, et vu qu'il n'y a aucune opération de calcul sur les case à cocher, je vais juste passer par un caractère sous la police wingdings, avec une macro double-clic qui vient modifier la valeur.
Le code n'est pas fini, et je n'ai pas encore ajouter le code pour le double-clic, mais je pense que tu verras l'idée, tu as l'air d'avoir bien plus de connaissances que moi X).
Merci encore pour ton retour !
23nouvelle-embauche-anonyme-v2.xlsm
Le 26/11/2021 à 17:38
Dan
- Messages
- 14'584
- Fichiers
- 2
- Votes
- 2'443
- Excel
- 2016 FR, Mac 2011
- Tél.
- 7'221
- Inscrit
- 27/04/2007
- Emploi
- Retraité
- Lieu
- Liège - Belgique
Bonjour,
Bonne approche pour vos cases à cocher construites via la police wingdings ! mais votre code peut être plus simple pour éviter toutes ces variables.
Dans l'attente du retour de Yal_Excel, je pense que ceci peut vous aider --> https://forum.excel-pratique.com/s/goto/891743 ou ceci qui est mieux pour vous --> https://forum.excel-pratique.com/s/goto/924244. Votre code double click peut être réalisé en 7 lignes max
NB : Juste pour votre info. Dans vos codes lorsque vous déclarez --> Dim Col1, Col2, Col3 As String --> Col1 et col2 sont de type Variant et non String. Seul col3 de type String.
Idem pour lg1, ..... qui sont toutes de type Variant
Dans votre cas vous pouvez plutot mettre tout en Byte --> Dim Col1 as byte, Col2 as byte, Col3 as byte
Cordialement
Notre éducation, nos valeurs et l'essentiel de notre vision du monde viennent des expériences que nous avons eues en grandissant (Steve Job)
Le 26/11/2021 à 18:04
y
yal_excel
- Messages
- 1'033
- Votes
- 287
- Excel
- PC 2010 Fr
- Inscrit
- 11/05/2021
Version adaptée au nouveau design. J'ai désactivé ton code qui n'est pas utile avec les modifs que j'ai faites
J'ai aussi intégré la gestion des coches, si tu veux changer l'apparence des cases c'est dans le code "Worksheet_SelectionChange" de la feuille "Checklist
Les cases à cocher avec windings je connaissais, dans ta première version les cases semblaient intégrées au texte dans la cellule. C'est ce qui m'a interpelé.
19nouvelle-embauche-anonyme-v3.xlsm
Dernière édition : le 26/11/2021 à 18:48
Le 26/11/2021 à 18:18
S
ShadowHitano
- Messages
- 6
- Excel
- 2016 FR
- Inscrit
- 26/11/2021
Merci pour ce retour Dan et merci pour les liens.
Le code que vous utilisez pour les "cases à cocher" est sensiblement identique à celui que j'avais l'intention d'ajouter, ce qui me rassure.
Quant aux variables, je suis totalement d'accord avec vous. Ces déclarations m'ont fortement dérangé. Je sais qu'il y a moyen de faire mieux et surtout bcp plus court. Mais je vous avoue que mes connaissance ne me permettent pas en l'état de gérer autrement des plages de données avec des intersections.
Je ne connais pas la méthodo pour traiter autant de range différentes en une seule fois.
Bien à vous
Le 26/11/2021 à 18:27
S
ShadowHitano
- Messages
- 6
- Excel
- 2016 FR
- Inscrit
- 26/11/2021
Merci encore pour ce retour
Tout était presque parfait, j'ai juste rajouté les case à cocher qui ne sont pas dynamique puisque les données sont en dur, et qui par conséquent n'entraient pas dans le traitement automatique via tableau.
En effet, sur la première version, les cases à cocher étaient bien des objets, ce qui me dérangeait un peu quand au poids du fichier, et à la vitesse d’exécution. D'autant que quand on travail avec ce type d'objet, on finit fatalement par rencontrer des problèmes. D'où le changement de fusil d'épaule et le traitement par police windings et maccro double clic.
Je vous souhaite à tous un bien bon week-end.
Le 26/11/2021 à 18:29
Dan
- Messages
- 14'584
- Fichiers
- 2
- Votes
- 2'443
- Excel
- 2016 FR, Mac 2011
- Tél.
- 7'221
- Inscrit
- 27/04/2007
- Emploi
- Retraité
- Lieu
- Liège - Belgique
Le code que vous utilisez pour les "cases à cocher" est sensiblement identique à celui que j'avais l'intention d'ajouter, ce qui me rassure.
A titre d'exemple, vous mettez simplement ce code dans la feuille Checklist, cela fera ce que vous demandez
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)If Not Intersect(Target, Range("B12:B15,B18,B24:B26,B32:B35,B37:B40,D16")) Is Nothing Then Cancel = False With Target .Font.Name = "Wingdings 2" .Font.Size = 12 If .FormulaR1C1 = "R" Then .FormulaR1C1 = "£" Else: .FormulaR1C1 = "R" End With Cancel = TrueEnd IfEnd Sub
Cordialement
Notre éducation, nos valeurs et l'essentiel de notre vision du monde viennent des expériences que nous avons eues en grandissant (Steve Job)
Le 26/11/2021 à 18:52
y
yal_excel
- Messages
- 1'033
- Votes
- 287
- Excel
- PC 2010 Fr
- Inscrit
- 11/05/2021
Je viens de publier une version modifée qui intègre la gestion des cases. Je la remet parce que l'ayant éditée entre temps elle est peut être passée innapercue
18nouvelle-embauche-anonyme-v3.xlsm
Le 26/11/2021 à 19:33
S
ShadowHitano
- Messages
- 6
- Excel
- 2016 FR
- Inscrit
- 26/11/2021
NE pas tenir compte de ce message, je ne sais pas comment le supprimer
4nouvelle-embauche-anonyme-v4.xlsm
Le 26/11/2021 à 19:49
S
ShadowHitano
- Messages
- 6
- Excel
- 2016 FR
- Inscrit
- 26/11/2021
ACCES PREMIUM
Soutenez le site en devenant membre Premium et profitez de plusieurs options exclusives :
- Navigation sans publicités
- Option "No Tracking"
- Option "Mode Incognito"
- Option "Dark Mode"
Plus d'informations ...
J'ai étudié le fichier, et tout est vraiment parfait. J'ai fait les modifs nécessaires pour les case à cocher. il me restait deux petit* détails à résoudre.
Pour les données qui ne sont pas traités dans les tableaux ( A12:F15 / A32:F35 / A37:F40), il fallait qu’a chaque changement de valeur de E7, les cases soient réinitialisées en "¨" si en Colonne -1 il y a une valeur.
Il y en aura normalement toujours une, puisque les données sont en dures, sauf pour le duo C40/D40 ou C40 n'est pas forcément renseignée.
De plus, il y avait aussi une case a prendre en compte en D16.
J'ai fait les modifs, je soumet le fichier final a vérification, et pour aider d'autre personnes qui pourraient en avoir besoin.
Merci encore pour votre intervention qui me fut salutaire.
Je vous souhaite un excellent week-end
85nouvelle-embauche-anonyme-v4.xlsm