Méthode itérative Excel pour décomposer champ
Résolu
coco49rico
-
rico49-29 Messages postés 5 Statut Membre -
rico49-29 Messages postés 5 Statut Membre -
Bonjour,
Je souhaite développer une macro qui décompose des cellules.
Le contenu d'une cellule par exemple:
C1-C10;C12-C14;C15;C17-C20
ou
TP2-TP5; TP6-TP11
...
Le point virgule est le séparateur et le tiret indique une plage.
Mon problème:
comment transformer ces exemples de cellule en
C1;C2;C3;C4;C5;C6;C7;C8;C9;C10;C12;C13;14;C5;C17;C18;C19;C20
ou
TP2;TP3;TP4;TP5;TP6;TP7;TP8;TP9;TP10;TP11
Merci pour votre aide,
Rico
Je souhaite développer une macro qui décompose des cellules.
Le contenu d'une cellule par exemple:
C1-C10;C12-C14;C15;C17-C20
ou
TP2-TP5; TP6-TP11
...
Le point virgule est le séparateur et le tiret indique une plage.
Mon problème:
comment transformer ces exemples de cellule en
C1;C2;C3;C4;C5;C6;C7;C8;C9;C10;C12;C13;14;C5;C17;C18;C19;C20
ou
TP2;TP3;TP4;TP5;TP6;TP7;TP8;TP9;TP10;TP11
Merci pour votre aide,
Rico
A voir également:
- Méthode itérative Excel pour décomposer champ
- Liste déroulante excel - Guide
- Word et excel gratuit - Guide
- Si ou excel - Guide
- Déplacer colonne excel - Guide
- Comment trier par ordre alphabétique sur excel - Guide
4 réponses
Bonjour,
Voir deux fonctions...
1°) "Replace" pour changer les tirets par des ; (point-virgule)
2°) "Split" pour tout séparer
Si tu ne connaît pas ces fonctions, double clic pour mettre le mot en surbrillance (sélectionner) et tape F1.
A+
Voir deux fonctions...
1°) "Replace" pour changer les tirets par des ; (point-virgule)
2°) "Split" pour tout séparer
Si tu ne connaît pas ces fonctions, double clic pour mettre le mot en surbrillance (sélectionner) et tape F1.
A+
Merci pour la réponse mais cela ne réponds pas à ma problématique de la transformation de C1-C10 en C1;C2;C3;C4;C5;C6;C7;C8;C9;C10
Rico
Rico
Effectivement,
Mais avec cette macro ça devrait aller...
A+
Mais avec cette macro ça devrait aller...
Sub Remplace()
Dim Test As String, C As String, i As Integer, e As Integer, TB1, TB2
Dim Deb As Integer, Fin As Integer, Lettre As String
Dim Result As String
Test = "C1-C10;C12-C14;C15;C17-C20"
TB1 = Split(Test, ";")
For i = 0 To UBound(TB1)
TB2 = Split(TB1(i), "-")
If UBound(TB2) = 0 Then 'quand il n'y à qu'une donnée
If Result <> "" Then Result = Result & ";"
Result = Result & TB2(0)
Else
C = ""
For e = 1 To Len(TB2(0)) 'début de la série
If Asc(Mid(TB2(0), e, 1)) < 65 Then Exit For
Next e
Deb = Val(Mid(TB2(0), e))
Lettre = Left(TB2(0), e - 1)
For e = 1 To Len(TB2(1)) 'fin de la série
If Asc(Mid(TB2(0), e, 1)) < 65 Then Exit For
Next e
Fin = Val(Mid(TB2(1), e))
For e = Deb To Fin
C = C & ";" & Lettre & e
Next e
If Result <> "" Then Result = Result & ";"
Result = Result & Mid(C, 2)
End If
Next i
End Sub
A+