Changer les liens hypertextes automatiquement en vba excel

[Résolu/Fermé]
Signaler
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021
-
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021
-
Bonjour,

Sous excell je cherche à programmer une macro qui génère des liens hypertextes automatiques dans le ^m classeur lors d'une copie et création d'une nouvelle feuille.
je m'explique dans une feuille j'ai 4 ou 5 boutons de lien hypertexte pour aller directement a une adresse voulu par exemple page haut et page bas, a chaque fois en cliquant sur un bouton nouvelle feuille je change manuellement les liens hypertextes au non de la feuille crée.
question: comment est ce que je peu écrire sous vba pour changer automatiquement les liens hypertextes au nom de la feuille crée
merci d'avance.

4 réponses

Messages postés
33731
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
22 octobre 2021
3 770
Bonjour,

Déjà.. il faudrait lancer les codes dans l'ordre....
Ensuite... pourquoi ne pas appliquer le code que l'on t'a donné....
Et enfin.. il aurait été bien que ta première feuille contienne des liens qui marchent... sinon les copies.. ben.. elles ne fonctionnent pas non plus !

Bref...
vu que le nom de tes feuilles contiennent des tirets, il faut en effet légèrement modifié mon code.

Donc voici ton code corrigé et fonctionnel
Sub Groupe59_QuandClic()

ActiveSheet.Copy after:=Sheets(Sheets.Count)
[c7].Value = [c7].Value + 1
[A843].Value = [C843].Value
'test = Application.Proper(Format(Range("e779"), "mmm-yyyy"))
ActiveSheet.Name = "Nov-2017"

Call modifiLink

End Sub

Sub modifiLink()
Dim sh As Worksheet
Dim L As Hyperlink
Dim exclapos  As Integer
Dim strFPrec  As String
'On défini la feuille active
Set sh = ActiveSheet
Debug.Print (sh.Name)
'On boucle sur chaque lien de la feuille
For Each L In sh.Hyperlinks
    'On trouve l'emplacement du !
    exclapos = InStr(1, L.SubAddress, "!", vbTextCompare)
    'Nom de la feuille précédente
    strFPrec = Mid(L.SubAddress, 1, exclapos - 1)
    'On remplace par le nom de la feuille actuelle
    
    L.SubAddress = Replace(L.SubAddress, strFPrec, "'" & sh.Name & "'")
    
Next
End Sub

1
Merci

Quelques mots de remerciements seront grandement appréciés. Ajouter un commentaire

CCM 41713 internautes nous ont dit merci ce mois-ci

Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021
1
merci beaucoup monsieur, enfin mon problème est bien résolu et ça marche très bien
vive le forum et encore merci pour votre aide.
Messages postés
17127
Date d'inscription
lundi 9 juin 2008
Statut
Contributeur
Dernière intervention
21 octobre 2021
910
bonjour, tu peux t'inspirer de ceci, qui affiche des infos pour tous les hyperliens du classeur:
Sub allhyper()
Dim ws As Worksheet
Dim hp As Hyperlink
For Each ws In ThisWorkbook.Sheets
    For Each hp In ws.Hyperlinks
        Debug.Print ws.Name, hp.Name, hp.SubAddress, hp.TextToDisplay
    Next hp
Next ws
End Sub

si je comprends ce que tu souhaites faire, tu devrais donc simplement modifier l'attribut
SubAddress
des liens présents sur la nouvelle feuille.
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021
1
re
SubAddress : je veux remplacer par le non de la nouvelle feuille (test)
comment est ce que je peu introduire cette écriture dans mon macro ( copie et création de nouvelle feuille):
Sub Groupe59_QuandClic()
ActiveSheet.Copy after:=Sheets(Sheets.Count)
[c7].Value = [c7].Value + 1
[A843].Value = [C843].Value
test = Application.Proper(Format(Range("e779"), "mmm-yyyy"))
ActiveSheet.Name = test
End Sub
Messages postés
17127
Date d'inscription
lundi 9 juin 2008
Statut
Contributeur
Dernière intervention
21 octobre 2021
910 >
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021

Jordane a fait tout le travail pour toi en #2, il ne te reste plus qu'à copier son code.
Messages postés
33731
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
22 octobre 2021
3 770
Bonjour,

Un truc du genre
Sub actualiseLiens()
Dim sh As Worksheet
Dim L As Hyperlink
Dim exclapos  As Integer
Dim strFPrec  As String

'On défini la feuille active
Set sh = ActiveSheet

'On boucle sur chaque lien de la feuille
For Each L In sh.Hyperlinks
    'On trouve l'emplacement du !
    exclapos = InStr(1, L.SubAddress, "!", vbTextCompare)
    'Nom de la feuille précédente
    strFPrec = Mid(L.SubAddress, 1, exclapos - 1)
    'On remplace par le nom de la feuille actuelle
    L.SubAddress = Replace(L.SubAddress, strFPrec, sh.Name)
Next

End Sub



Cordialement, 
Jordane                                                                 
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021
1 >
Messages postés
33731
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
22 octobre 2021

bonjour
j'ai changer ,mais toujours la m^chose j'attire votre attention que j"utilise des boutons comme lien hypertexte.
Messages postés
33731
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
22 octobre 2021
3 770 >
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021

Hein ??
Dans ce cas.. pourrais tu partager ton fichier ?
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021
1 >
Messages postés
33731
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
22 octobre 2021

https://www.cjoint.com/doc/17_11/GKyjOsX4RyH_TVA-20-17.xls
a chaque fois que je clique sur mois suivant je change le nom de la feuille manuellement dans les autres boutons en cliquant sur modifié le lien hypertexte et je selectionne la nouvelle feuille crée.
merci et bonne journée
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021
1 >
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021

re
au niveau de mon macro (mois prochain) est ce que c'est juste ce que j'ai écrit ou on peu faire autrement(mieu faire) ( le but est de copier la feuille et coller dans une nouvelle feuille mois qui suit et ajouter 1 au cellule c7 et la valeur de a843 prend c843)
j'attend votre intervention
merci d'avance a tous
Messages postés
17127
Date d'inscription
lundi 9 juin 2008
Statut
Contributeur
Dernière intervention
21 octobre 2021
910 >
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021

je n'ai pas de problème avec le fichier envoyé.
deux choses bizarres:
1) le code proposé n'est pas dans le fichier?
2) il n'y a qu'une seule feuille dans le fichier.
Messages postés
150
Date d'inscription
lundi 1 mai 2017
Statut
Membre
Dernière intervention
16 août 2021
1
bonsoir
vous avez raison pardon si je m'explique mal, je vous renvoi le fichier avec le code proposé.
https://www.cjoint.com/c/GKywef3Wg21
merci pour votre aide et votre collaboration