IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Remplacer code par libellé


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 67
    Par défaut Remplacer code par libellé
    Bonjour,

    J'ai un classeur.
    Sur une des feuilles, dans une colonne figure des codes (5, 12 , 30....) . La feuille varie chaque mois

    J'ai créé un deuxième classeur, avec sur une feuille la signification de ces codes ( 5 = Gazole ; 12 = Péage ; 30 = Super,....) .Ces données restent stables

    Mon objectif : remplacer les codes du permier classeur par leur signification correspondante...

    J'avais pensé à utiliser le .find (mais avec plus de 3000 lignes), je me demande si ma solution serait la plus optimale....

  2. #2
    Membre Expert
    Inscrit en
    Août 2006
    Messages
    1 588
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 1 588
    Par défaut
    Bonjour,

    je propose cette solution
    module à intégrer dans le fichier de données, lancer Transpose
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
     
    Sub Transpose()
     Dim wk1 As Workbook, wk2 As Workbook, ligne As Long
     
     Set wk1 = ActiveWorkbook
     Workbooks.Open Filename:="c:\excel\liste.xls"
     Set wk2 = ActiveWorkbook
     
     wk1.Activate
     
     ligne = 1
     With wk1.Sheets("Feuil1")
      Do Until .Cells(ligne, 1) = ""
       If .Cells(ligne, 1) > 0 Then
        .Cells(ligne, 1) = wk2.Sheets("Feuil1").Cells(.Cells(ligne, 1), 2)
       End If
       ligne = ligne + 1
      Loop
     End With
     wk2.Close
     
    End Sub
    cela semble rapide mais il faut que le nombre 5 pour gazole, 12 pour péage soient sur les lignes 5 , 12, etc du 2ème fichier
    Il y a peut-être des tests de validité supplémentaires à effectuer.

  3. #3
    Membre Expert Avatar de aalex_38
    Inscrit en
    Septembre 2007
    Messages
    1 631
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 631
    Par défaut
    Un exemple avec la fonction replace :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Columns("A:A").Replace What:="5", Replacement:="Gazole", LookAt:=xlWhole, _
            SearchOrder:=xlByColumns, MatchCase:=False, SearchFormat:=False, _
            ReplaceFormat:=False

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Datagridview : remplacer 1 code par 1 string
    Par belote dans le forum Windows Forms
    Réponses: 3
    Dernier message: 11/12/2007, 09h11
  2. Remplacement du code par une requete
    Par Lorenzogazier dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 30/11/2007, 10h19
  3. remplacer du code par une fonction
    Par bullrot dans le forum C++Builder
    Réponses: 6
    Dernier message: 21/11/2007, 12h08
  4. Réponses: 5
    Dernier message: 14/12/2006, 16h50
  5. Réponses: 4
    Dernier message: 13/10/2005, 14h44

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo