InputBox pour renommer le nom d'une feuille
Résolu
tchics
Messages postés
6
Statut
Membre
-
tchics Messages postés 6 Statut Membre -
tchics Messages postés 6 Statut Membre -
Bonjour,
Tout d'abord merci car, sans le savoir, vous m'aider depuis quelques jours dans l'avancé de mon projet.
Actuellement je bloque sur une macro qui pourrait renommer une feuille suite au renseignement d'une InputBox
Cette feuille est créer en dupliquant une feuille qui me sert de trame (donc nommer trame(2) de base)
voici le code actuel :
Vous l'aurez compris, je débute en vba
Merci de m'éclairez de vos lumières
Tout d'abord merci car, sans le savoir, vous m'aider depuis quelques jours dans l'avancé de mon projet.
Actuellement je bloque sur une macro qui pourrait renommer une feuille suite au renseignement d'une InputBox
Cette feuille est créer en dupliquant une feuille qui me sert de trame (donc nommer trame(2) de base)
voici le code actuel :
Sub Creer_unite_travail() Sheets("Trame").Select Sheets("Trame").Copy Before:=Sheets(1) Dim b As String 'déclare la variable b b = InputBox("Nom de l'unité de travail ?", "Question ?") 'tentative dans une cellule : marche pas ' ActiveSheets.Range("B1").Value = b 'tentative de renommer la feuille active : marche pas' ActiveSheets.Name = b End Sub
Vous l'aurez compris, je débute en vba
Merci de m'éclairez de vos lumières
A voir également:
- InputBox pour renommer le nom d'une feuille
- Renommer des fichiers en masse - Guide
- Renommer iphone - Guide
- Bruler feuille de laurier - Guide
- Comment imprimer en a5 sur une feuille a4 - Guide
- Comment supprimer une feuille sur word - Guide
4 réponses
Bonsoir tchics,
Je pense que le plus facile est de poser la question et seulement après tu copies la feuille et la renomme.
Une façon de faire:
Tu fais appel à cette procédure comme ceci:
Bon dimanche.
Je pense que le plus facile est de poser la question et seulement après tu copies la feuille et la renomme.
Une façon de faire:
Private Sub RecupNomOnglet(Optional ByVal NouvelleFeuille As String = "") If(NouvelleFeuille="") Then Exit Sub ' Sheets("Trame").Copy After:=Sheets(Sheets.Count) ' Entre le nom du chantier ds la cellule A1 Activesheet.Name = NomFeuille End Sub
Tu fais appel à cette procédure comme ceci:
Call RecupNomOnglet("NomDeLaNouvelleFeuille")
Bon dimanche.
Bonjour Heliotte et merci de ta réponse
En creusant un peu j'ai trouvé une solution qui fonctionne apparemment
Voici le code (j'imagine qu'il doit y avoir mieux mais pour l'instant ça marche)
Je suis ouvert aux critiques ;0)
Bonne journée
En creusant un peu j'ai trouvé une solution qui fonctionne apparemment
Voici le code (j'imagine qu'il doit y avoir mieux mais pour l'instant ça marche)
Sub Creer_unite_travail() ActiveSheet.Unprotect 'affiche la trame pour selection/copier/coller puis disparait' Sheets("Trame").Visible = True Sheets("Trame").Select Sheets("Trame").Copy Before:=Sheets(1) Sheets("Trame").Visible = False Dim b As String Dim c As String Dim d As String b = InputBox("Nom de l'unité de travail ?", "Question ?", "Nom de l'unité") 'impose de répondre' If Len(b) < 1 Then MsgBox ("Vous devez obligatoirement entrer un nom d'unité de travail") End If While Len(b) < 1 MsgBox ("Vous devez obligatoirement entrer un nom d'unité de travail") b = InputBox("Nom de l'unité de travail ?", "Question ?") Wend c = InputBox("Effectif de l'unité de travail ?", "Question ?") d = InputBox("Nom du rédacteur ?", "Question ?") Range("B1").Select ActiveCell.FormulaR1C1 = b Range("B2").Select ActiveCell.FormulaR1C1 = c Range("N1").Select ActiveCell.FormulaR1C1 = d ActiveSheet.Name = b 'couleur de l'onglet aléatoire' ActiveSheet.Tab.Color = RGB(Int(256 * Rnd), Int(256 * Rnd), Int(256 * Rnd)) ActiveSheet.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True _ , AllowInsertingRows:=True, AllowDeletingRows:=True End Sub
Je suis ouvert aux critiques ;0)
Bonne journée
Bonjour,
1- la déclaration des variables se fait toujours en tête de procédure.
2- tu doublonnes ici :
3- Les .Select sont inutiles
4- Si dans b est saisi le nom d'une feuille déjà existante, que se passe t'il avec ton code???
5- ne pas mettre, dans ton cas, de valeur par défaut dans l'inputbox b, sous risque de se retrouver avec une feuille nommée "Nom de l'unité"...
Correction envisagée :
1- la déclaration des variables se fait toujours en tête de procédure.
2- tu doublonnes ici :
b = InputBox("Nom de l'unité de travail ?", "Question ?", "Nom de l'unité") 'impose de répondre' If Len(b) < 1 Then MsgBox ("Vous devez obligatoirement entrer un nom d'unité de travail") End If While Len(b) < 1 MsgBox ("Vous devez obligatoirement entrer un nom d'unité de travail") b = InputBox("Nom de l'unité de travail ?", "Question ?") Wend
3- Les .Select sont inutiles
4- Si dans b est saisi le nom d'une feuille déjà existante, que se passe t'il avec ton code???
5- ne pas mettre, dans ton cas, de valeur par défaut dans l'inputbox b, sous risque de se retrouver avec une feuille nommée "Nom de l'unité"...
Correction envisagée :
Sub Creer_unite_travail() Dim b As String Dim c As String Dim d As String ActiveSheet.Unprotect 'affiche la trame pour selection/copier/coller puis disparait' With Sheets("Trame") .Visible = True .Copy Before:=Sheets(1) .Visible = False End With While Len(b) < 1 b = InputBox("Nom de l'unité de travail ?", "Question ?") If Len(b) < 1 Then MsgBox ("Vous devez obligatoirement entrer un nom d'unité de travail") End If If FeuilleExiste(ThisWorkbook, b) Then MsgBox "La feuille " & b & " existe déjà. Changez de nom." b = "" End If Wend c = InputBox("Effectif de l'unité de travail ?", "Question ?") d = InputBox("Nom du rédacteur ?", "Question ?") Range("B1") = b Range("B2") = c Range("N1") = d ActiveSheet.Name = b 'couleur de l'onglet aléatoire' ActiveSheet.Tab.Color = RGB(Int(256 * Rnd), Int(256 * Rnd), Int(256 * Rnd)) ActiveSheet.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True _ , AllowInsertingRows:=True, AllowDeletingRows:=True End Sub 'Fonction de Bbil, sources : 'http://www.developpez.net/forums/d269391/logiciels/microsoft-office/excel/macros-vba-excel/vba-e-feuille-existe/ Function FeuilleExiste(wk As Workbook, stFeuille) As Boolean On Error Resume Next FeuilleExiste = Not (wk.Sheets(stFeuille) Is Nothing) End Function
Salut pijaku et merci ,
Effectivement je doublonne et je crache si même nom de feuille. Je vais tester tout ça et te ferait un retour. Au passage mes onglet sont de couleurs aléatoires car je n'ai pas réussi à leur imposer des couleurs différentes à chaque nouvelle création.
Aurait tu une piste (je suis sur que oui ^^)
Merci
Effectivement je doublonne et je crache si même nom de feuille. Je vais tester tout ça et te ferait un retour. Au passage mes onglet sont de couleurs aléatoires car je n'ai pas réussi à leur imposer des couleurs différentes à chaque nouvelle création.
Aurait tu une piste (je suis sur que oui ^^)
Merci
Pour les couleurs des onglets...
- boucle sur toutes les feuilles,
- récupère les couleurs des onglets dans une variable tableau,
- boucle qui : créé aléatoirement une couleur et vérifie si cette couleur n'est pas déjà en place.
Ca donne quelque chose comme :
- boucle sur toutes les feuilles,
- récupère les couleurs des onglets dans une variable tableau,
- boucle qui : créé aléatoirement une couleur et vérifie si cette couleur n'est pas déjà en place.
Ca donne quelque chose comme :
Sub Principale() Call AppliqueNouvelleCouleurOnglet(ActiveSheet) End Sub Sub AppliqueNouvelleCouleurOnglet(Feuille As Worksheet) Dim Wsh As Worksheet, Couleurs(), i As Integer, Flag As Boolean, Couleur As Long For Each Wsh In ThisWorkbook.Worksheets ReDim Preserve Couleurs(i) Couleurs(i) = Wsh.Tab.Color i = i + 1 Next Wsh Flag = False Do While Flag = False Randomize Couleur = RGB(Int(256 * Rnd), Int(256 * Rnd), Int(256 * Rnd)) For i = LBound(Couleurs) To UBound(Couleurs) If Couleur = Couleurs(i) Then Flag = False Exit For End If Flag = True Next Loop Feuille.Tab.Color = Couleur End Sub
Je me rends compte que la méthode utilisée n'est pas valable...
En effet, les couleurs de type "Long" ne sont pas différenciées par excel... tu risques de te retrouver avec deux couleurs (13421619 et 13421620 par exemple) qui sont différentesz en programmation mais identique à la vue...
Je regarde cela de plus près...
De plus, la propriété ColorIndex ne laisse que 56 choix... Auras tu plus de 56 onglets??????
En effet, les couleurs de type "Long" ne sont pas différenciées par excel... tu risques de te retrouver avec deux couleurs (13421619 et 13421620 par exemple) qui sont différentesz en programmation mais identique à la vue...
Je regarde cela de plus près...
De plus, la propriété ColorIndex ne laisse que 56 choix... Auras tu plus de 56 onglets??????
Pour exemple, avec commentaires :
Sub AppliqueNouvelleCouleurOngletAleatoirement() Dim Wsh As Worksheet Dim Couleurs(55) As Integer, i As Integer, Coul As Integer Dim Dico As Object 'teste le nombre d'onglets. Si > 56 on ne peux rien faire avec ce code. If Sheets.Count > 56 Then MsgBox "Votre classeur contient trop de feuilles.": Exit Sub 'On remplit la variable tableau avec toutes les valeurs que peux prendre 'la propriété ColorIndex soit de 1 à 56 For i = 0 To 55 Couleurs(i) = i + 1 Next 'L'objet Dictionary permet de générer des listes sans doublons Set Dico = CreateObject("Scripting.Dictionary") 'On implémente notre dictionary avec les couleurs des onglets déjà existants For Each Wsh In ThisWorkbook.Worksheets Dico(Wsh.Tab.ColorIndex) = "" Next Wsh Randomize Do 'On détermine une couleur aléatoirement Coul = CInt(Rnd * 55) 'si cette couleur n'existe pas dans notre dictionary 'En même temps on vérifie qu'il s'agit d'une couleur valide pour 'la propriété ColorIndex (si > 0 et < 57) If Not Dico.exists(Coul) And Coul > 0 And Coul < 57 Then 'si tout bon alors on l'applique à notre onglet ActiveSheet.Tab.ColorIndex = Coul 'on sort de la boucle Do-Loop Exit Do End If Loop End Sub