VBA remplacer une colonne en majuscule [Résolu]

Marie Chant 78 Messages postés lundi 24 mars 2014Date d'inscription 18 mai 2017 Dernière intervention - 9 févr. 2017 à 15:22 - Dernière réponse : Marie Chant 78 Messages postés lundi 24 mars 2014Date d'inscription 18 mai 2017 Dernière intervention
- 9 févr. 2017 à 16:18
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.


Afficher la suite 

2 réponses

Répondre au sujet
michel_m 14972 Messages postés lundi 12 septembre 2005Date d'inscriptionContributeurStatut 17 janvier 2018 Dernière intervention - Modifié par michel_m le 9/02/2017 à 16:17
0
Utile
1
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
Marie Chant 78 Messages postés lundi 24 mars 2014Date d'inscription 18 mai 2017 Dernière intervention - 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
Commenter la réponse de michel_m