CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[VBA] erreur introuvable....

callix
callix
Niveau 10
21 avril 2006 à 13:20:44

voilà, j´utilise ce petit programme (trouvé sur le net) afin de copier ma feuille "calculs" et de nommer la copie position i (i étant un nombre.)
Ce programme a bien fonctionné les premiéres fois mais depuis que j´essaie de le modifier, il refuse de fonctionner....
j´ai une erreur d´incompatibilité de type à la ligne:
i = WorksheetFunction.Max(i, CInt(Mid(S.Name, Len(PREFIX) + 1)) + 1)

voici, le listing du programme:
Sub copier()

Const PREFIX = "Position "
Dim i As Integer

i = 1

For Each S In Sheets
If Left(S.Name, Len(PREFIX)) = PREFIX Then
i = WorksheetFunction.Max(i, CInt(Mid(S.Name, Len(PREFIX) + 1)) + 1)
End If
Next
Sheets("calculs").Copy After:=Sheets(Sheets.Count)
Sheets(Sheets.Count).Name = PREFIX & i
End Sub

Merci d´avance

godrik
godrik
Niveau 30
21 avril 2006 à 13:45:11

Je n´y connais pas grand chose, mais il n´y a pas des options de debuggage disponible du genre: "option error on" ou encore "option explicit" qui pourrait t´aider ?

callix
callix
Niveau 10
21 avril 2006 à 14:01:01

si mais ça ne m´avance pas...

Je viens de tester cette procédure dans un classeur vierge et.... ça fonctionne.
Si je la remet dans mon classeur sur lequel je travail: ça bug.
J´y perd mon latin.

dnob700
dnob700
Niveau 10
21 avril 2006 à 15:33:15

Tu pourrais nous donner le message d´erreur précis ?

Mais j´ai l´impression que c´est le Len(PREFIX)+1 qui cloche, car je ne vois pas pourquoi tu as besoin d´un +1 vu que prefix compte déjà un espace.

Alors mid doit renvoyer une chaine vide "". Je ne pense pas que ça gèen CInt qui devrait renvoyer 0, mais ce n´est pas peut-être pas le cas (mais si oui, tu essayerai d´appeler toute tes feuilles "Position 1" et je nesais pas si tes feuilles ont le droit d´avoir le même nom.

callix
callix
Niveau 10
21 avril 2006 à 15:40:12

eh bien....
je vais pas pouvoir te donner le message d´erreur car.... aprés un plantage d´excel... ca remarche.
J´y comprend vraiment rien.

le message s´était juste : "erreur
d"éxécution 13: incompatibilité de type"
je vais continuer à tester...

callix
callix
Niveau 10
21 avril 2006 à 15:48:34

bon, je vais trouver une autre méthode...
je ne ferais qu´une seule copie et si une copie existe déjà, je la supprimerais.

Sous forums
  • Aide à l'achat Mac
  • Macintosh
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Internet
  • Steam Deck
  • Hardware
La vidéo du moment