Signaler

VBA remplacer une colonne en majuscule [Résolu]

Posez votre question Marie Chant 73Messages postés lundi 24 mars 2014Date d'inscription 9 février 2017 Dernière intervention - Dernière réponse le 9 févr. 2017 à 16:18 par Marie Chant
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 
Utile
+0
moins plus
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)
Marie Chant 73Messages postés lundi 24 mars 2014Date d'inscription 9 février 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
Répondre
Donnez votre avis

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes.

Le fait d'être membre vous permet d'avoir des options supplémentaires.

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !