VBA remplacer une colonne en majuscule

Résolu/Fermé
Marie Chant Messages postés 106 Date d'inscription lundi 24 mars 2014 Statut Membre Dernière intervention 12 juillet 2024 - 9 févr. 2017 à 15:22
michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 - 12 janv. 2023 à 14:25
Bonjour,

Je ne suis pas très bien expérimenté en VBA alors je vous demande votre aide. J'ai déjà une macro mais cela prend beaucoup trop de temps pour l'exécution alors je ne crois pas que c'est la meilleure macro.

Je vous explique mon problème.

Dans ma colonne A j'ai des no factures d'inscrit soit:
Colonne A
Ligne 1 de12356
Ligne 2 CP1230
Ligne 3 GL2640
Ligne 4 gl2641
Ligne 5 le1236
Et d'une fois a l'autre une nombre de ligne est différent et souvent en haut de 5000 lignes.
Je veux que ma macro mettre toutes les lettres en majuscules.

Je mets ma colonne A en surbrillance et je lance cette macro:

Sub Majuscules()
Dim Cells As range
For Each Cells In Selection
Cells.Value = UCase(Cells.Value)
Next Cells
End Sub

Cela fonctionne MAIS c'est beaucoup trop long à exécuter. je ne sais pas comment faire pour accélérer la macro.

Pourriez-vous m'aider s.v.p.


je vous remercie de votre aide.


A voir également:

1 réponse

michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 3 310
Modifié par michel_m le 9/02/2017 à 16:17
Bonjour

test sur 14000 lignes. durée: 0,12 secodes
Option Explicit
'--------------------------------------
Sub mettre_majuscules()
Dim Derlig As Integer, T_min, Cptr As Integer
Dim start As Single
start = Timer
Derlig = Columns("A").Find(what:="*", searchdirection:=xlPrevious).Row
T_min = Range("A1:A" & Derlig)
For Cptr = 1 To UBound(T_min)
T_min(Cptr, 1) = UCase(T_min(Cptr, 1))
Next
Range("A1").Resize(UBound(T_min)) = T_min
MsgBox Derlig & " lignes en " & Round(Timer - start, 2) & " sec"
End Sub


pour le fun; 5000 lignes en 0,08 secondes ;o)
 Michel
1
Marie Chant Messages postés 106 Date d'inscription lundi 24 mars 2014 Statut Membre Dernière intervention 12 juillet 2024 5
9 févr. 2017 à 16:18
Bonjour Michel,

merci beaucoup. C'est vraiment HOT cette macro. WOW!

Elle fonctionne super bien, encore merci et bonne journée
1

bonsoir michel,

ce code est celui que je cherchais par contre pouvez le mettre sans le message du timing ? svp

1
michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 3 310 > alex
12 janv. 2023 à 14:25

Bonlpour

paz trop compris la demande... mais pour su^^rimer le message de fin(durée du traitement...?

supprimer les lignes

Range("A1").Resize(UBound(T_min)) = T_min
MsgBox Derlig & " lignes en " & Round(Timer - start, 2) & " sec"

et aussi

Dim start As Single
start = Timer
0