Rechercher : dans
Par :

[VBA Excel] supprimer le point virgule

Dernière réponse le 27 jui 2006 à 11:44:41 ben7777, le 24 jui 2006 à 16:28:13 
 Signaler ce message aux modérateurs

Bonjour,

j'aimerai que les mots qui sont séparés par un point virgule dans ma cellule excel, apparaissent un à un dans des lignes différentes comme une énumération. En fait je voudrais exactement comme on fait avec la conversion de colonne en délimité mais avec des lignes. Et tout ca en VBA !

Merci de votre aide c'est assez urgent

Ben

Meilleures réponses pour « [VBA Excel] supprimer le point virgule » dans :
Eviter les doublons dans Excel VoirEviter les doublons lors d'un encodage dans un colonne de feuille excel: prendre le format conditionnel sur le première cellule sous les titres (par ex A2) choisir la formule suivante : =NB.SI($A$2:$A$21;A2)>1 mettre là la couleur de fond...

1

gbinforme, le 24 jui 2006 à 16:54:50

Bonjour

pour faire cela rapidement, je te propose cette macro :


Sub conv_lignes()
Dim col, car, k
Set col = Application.InputBox("Choisissez la colonne à convertir", "Colonne à convertir", , 100, 200, , , 8)
car = Application.InputBox("Choisissez le caractère délimiteur", "Caractère délimiteur", ";", 100, 100)
For Each c In Range(col.Address)
k = InStr(1, c.Value, car)
Do While k > 0
Cells(c.Row + 1, c.Column).EntireRow.Insert
Cells(c.Row + 1, c.Column).Value = Right(c.Value, Len(c.Value) - k)
Cells(c.Row, c.Column) = Left(c.Value, k - 1)
k = InStr(k + 1, c.Value, car)
Loop
Next c
End Sub


tu choisis ta plage à la souris, ton caractère délimiteur,
et la macro crée autant de lignes que nécessaire pour le choix.

les lignes qui sont tronquées ici doivent être remises sur la même.

Set col = Application.InputBox("Choisissez la colonne à convertir", "Colonne à convertir", , 100, 200, , , 8)

et

car = Application.InputBox("Choisissez le caractère délimiteur", "Caractère délimiteur", ";", 100, 100)

toujours zen

Répondre à gbinforme

2

ben7777, le 24 jui 2006 à 17:02:57

Alors la chapeau ! j'ai pas encore super bien analysé mais ca ma l'air parfait !
Merci beaucoup de ton aide

Répondre à ben7777

3

ben7777, le 24 jui 2006 à 18:04:38

Franchement c'est ce que je voulais alors bravo et merci ! j'ai juste une petite demande, je voudrais que le reste de la ligne soit copié aussi parce que là j'ai ma nouvelle ligne mais les champs des autres colonnes sont vides alors que j'aimerai qu'ils soient dupliqués .

Si tu as une idée ....

Merci encore

Répondre à ben7777

4

gbinforme, le 24 jui 2006 à 18:49:30

Bonjour

après la ligne : Cells(c.Row + 1, c.Column).EntireRow.Insert

tu rajoutes cette ligne :

Cells(c.Row, 1).Resize(2, 1).EntireRow.FillDown


tout est possible avec Excel, mais il faut y passer du temps,
et avoir des raisons pour cela.


toujours zen

Répondre à gbinforme

5

ben7777, le 25 jui 2006 à 10:38:50

Merci c'est génial !

Répondre à ben7777

6

ben7777, le 26 jui 2006 à 09:50:46

Je voulais savoir un truc : j'ai essayé de refaire la même chose pour que les champs séparés par le point virgules se mettent sur la meme ligne à présent. Alors il y a la conversion du texte en colonne avec le point virgule comme séparateur qui marche mais le problème c'est que ca me remplace le contenu des colonnes adjacentes à droite. Y a t il une solution ?

Merci ;-)

Répondre à ben7777

7

gbinforme, le 27 jui 2006 à 09:52:43

Bonjour

j'ai essayé de refaire la même chose pour que les champs séparés par le point virgules se mettent sur la meme ligne à présent.

C'est un peu plus compliqué effectivement à faire, voici la macro adaptée :

Sub conv_colonnes()
Dim col, car, k, j
Set col = Application.InputBox("Choisissez la colonne à convertir", "Colonne à convertir", , 100, 200, , , 8)
car = Application.InputBox("Choisissez le caractère délimiteur", "Caractère délimiteur", ";", 100, 100)
For Each c In Range(col.Address)
k = InStr(1, c.Value, car)
j = 0
Do While k > 0
j = j + 1
If Cells(c.Row, c.Column + j).Value <> "" Then Cells(c.Row, c.Column + j).EntireColumn.Insert
Cells(c.Row, c.Column + j).Value = Right(Cells(c.Row, c.Column + j - 1).Value, Len(Cells(c.Row, c.Column + j - 1).Value) - k)
Cells(c.Row, c.Column + j - 1).Value = Left(Cells(c.Row, c.Column + j - 1).Value, k - 1)
k = 0
k = InStr(k + 1, Cells(c.Row, c.Column + j).Value, car)
Loop
Next c
End Sub



Je penses que tu as vu l'intérêt du choix d'une plage à la souris pour les essais.

Bon essai et donnes nous le résultat...


toujours zen

Répondre à gbinforme

8

ben7777, le 27 jui 2006 à 09:59:30

Alors là merci beaucoup ! Mais comment faites vous ??
Merci encore ca m'aide vraiment d'autant que tu es le seul à me répondre.
C'est rassurant de se dire que quand on est en stage en galère ya des gens qui peuvent toujours nous aider !

Merci ;-)

Répondre à ben7777

9

 gbinforme, le 27 jui 2006 à 11:44:41

Bonjour

As-tu vu la macro pour les filtres automatiques ?

Mais comment faites vous ??

Avec Excel, comme pour beaucoup d'autres choses d'ailleurs,
il faut toujours travailler pour comprendre les notions de base,
puis mettre en pratique sur les domaines adéquats.

VBA possède une aide très complète, avec des exemples,
il faut apprendre à l'utiliser et après, il n'y a plus de limite...

Au bout de quelques années de pratique, tu peux utiliser,
de façon efficace, 20% des possibilités et ensuite,
il est toujours temps d'acquèrir d'autres notions...

toujours zen

Répondre à gbinforme