Macro pour inserer des lignes verticalements et copier des cellu
Résolu
bubu635863
Messages postés
14
Statut
Membre
-
michel_m Messages postés 18903 Statut Contributeur -
michel_m Messages postés 18903 Statut Contributeur -
Bonjour,
Voilà mon problème, j'ai un tableau Excel avec des données en colonnes et en lignes
je souhaiterais insérer 6 lignes entre chaque code de la colonne B ; que la cellule c2 vienne en b2, que la cellule d2 vienne en b4; que la cellule f2 vienne en b5 ; puis que la cellule b3 vienne en b7 et on recommence...
Mon tableau fait 6500 lignes... je sais que copier collage spécial / transposé le fait mais c'est un peu long :(
Je joins un petit fichier avec un exemple de mon tableau de base "onglet stliv" et ce que je souhaiterais en feuil1.
Merci pour votre aide.
Tableau de départ :
A B C D E F
1 Reference Qte cmd Code c1 Adresse PCX
2 Y001 48053026 1 11400 H1016 228
3 48092443 4 126 TG14 2.52
4 48070743 1 8000 H2024 160
5 68280800 1 F1008
6 66344012 2 C1009
7 63613501 1 B4008
8 Y002 68474294 3 A3003
9 65336600 1 A3003
10 61450991 1 A3003
Tableau d'arrivée :
A B
1 Y001 48053026
2 1
3
4 11400
5 228
6
7 48092443
8 4
9
10 126
11 2.52
12
13 48070743
14 1
15
16 8000
17 160
18
19 68280800
20 1
21
22
23
24
25 66344012
26 2
27
28
29
30
31 63613501
32 1
33
34
35
36
37 Y002 68474294
38 3
39
40
41
42
43 65336600
44 1
45
46
Voilà mon problème, j'ai un tableau Excel avec des données en colonnes et en lignes
je souhaiterais insérer 6 lignes entre chaque code de la colonne B ; que la cellule c2 vienne en b2, que la cellule d2 vienne en b4; que la cellule f2 vienne en b5 ; puis que la cellule b3 vienne en b7 et on recommence...
Mon tableau fait 6500 lignes... je sais que copier collage spécial / transposé le fait mais c'est un peu long :(
Je joins un petit fichier avec un exemple de mon tableau de base "onglet stliv" et ce que je souhaiterais en feuil1.
Merci pour votre aide.
Tableau de départ :
A B C D E F
1 Reference Qte cmd Code c1 Adresse PCX
2 Y001 48053026 1 11400 H1016 228
3 48092443 4 126 TG14 2.52
4 48070743 1 8000 H2024 160
5 68280800 1 F1008
6 66344012 2 C1009
7 63613501 1 B4008
8 Y002 68474294 3 A3003
9 65336600 1 A3003
10 61450991 1 A3003
Tableau d'arrivée :
A B
1 Y001 48053026
2 1
3
4 11400
5 228
6
7 48092443
8 4
9
10 126
11 2.52
12
13 48070743
14 1
15
16 8000
17 160
18
19 68280800
20 1
21
22
23
24
25 66344012
26 2
27
28
29
30
31 63613501
32 1
33
34
35
36
37 Y002 68474294
38 3
39
40
41
42
43 65336600
44 1
45
46
A voir également:
- Macro pour inserer des lignes verticalements et copier des cellu
- Insérer video powerpoint - Guide
- Comment insérer des points de suite sur word - Guide
- Partager des photos en ligne - Guide
- Telecharger macro convertir chiffre en lettre excel - Télécharger - Tableur
- Insérer table des matières word - Guide
3 réponses
Bonjour,
et il est où le "petit fichier" ?
merci de mettre environ 1500 lignes
pour joindre une pièce
mettre le classeur sans données confidentielles en pièce jointe sur
https://www.cjoint.com/
puis copier l'adresse du lien et la coller dans le message de réponse
et il est où le "petit fichier" ?
merci de mettre environ 1500 lignes
pour joindre une pièce
mettre le classeur sans données confidentielles en pièce jointe sur
https://www.cjoint.com/
puis copier l'adresse du lien et la coller dans le message de réponse
Bonjour
Macro possible pour transposer de Feuil1 en Feuil2 selon tes critères
Sub transposition()
un = "Feuil1"
deu = "Feuil2"
der = InputBox("N° de la dernière ligne à transposer ?")
lg = 2 'donc commencera à copier à partir de la ligne 2
For n = lg To der
a = a + 1
Sheets(deu).Cells(a, 1) = a
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 2).Value
a = a + 1
Sheets(deu).Cells(a, 1) = a
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 3).Value
a = a + 1
Sheets(deu).Cells(a, 1) = a
a = a + 1
Sheets(deu).Cells(a, 1) = a
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 4).Value
a = a + 1
Sheets(deu).Cells(a, 1) = a
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 6).Value
a = a + 1
Sheets(deu).Cells(a, 1) = a
Next
End Sub
Cdlmnt
Macro possible pour transposer de Feuil1 en Feuil2 selon tes critères
Sub transposition()
un = "Feuil1"
deu = "Feuil2"
der = InputBox("N° de la dernière ligne à transposer ?")
lg = 2 'donc commencera à copier à partir de la ligne 2
For n = lg To der
a = a + 1
Sheets(deu).Cells(a, 1) = a
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 2).Value
a = a + 1
Sheets(deu).Cells(a, 1) = a
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 3).Value
a = a + 1
Sheets(deu).Cells(a, 1) = a
a = a + 1
Sheets(deu).Cells(a, 1) = a
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 4).Value
a = a + 1
Sheets(deu).Cells(a, 1) = a
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 6).Value
a = a + 1
Sheets(deu).Cells(a, 1) = a
Next
End Sub
Cdlmnt
Top, merci ta macro à l'air de marcher du feu de dieux.
Par contre dans cette dernière, en colonne A, j'ai le numéro de ligne qui apparait ce que je ne souhaitait pas forcément.
J'ai rajouter sur le post précédent de Michel_m un lien (merci michel_m pour l'explication comment poster un lien...) avec le fichier en question et la "présentation" finale recherchée sur la Feuil1
Cordialement,
Par contre dans cette dernière, en colonne A, j'ai le numéro de ligne qui apparait ce que je ne souhaitait pas forcément.
J'ai rajouter sur le post précédent de Michel_m un lien (merci michel_m pour l'explication comment poster un lien...) avec le fichier en question et la "présentation" finale recherchée sur la Feuil1
Cordialement,
re top,
merci mais sans vouloir t'ennuyer, je souhaiterais que dans la colonne A apparaisse le Y001 en face du N° de référence concerné...
C'est difficile à expliquer, je te joins le fichier, je pense que ce sera plus simple de visu.
onglet STLIV = fichier de départ
Feuil1 = fichier souhaité
Merci encore.
https://www.cjoint.com/?0JepjInhbSa
merci mais sans vouloir t'ennuyer, je souhaiterais que dans la colonne A apparaisse le Y001 en face du N° de référence concerné...
C'est difficile à expliquer, je te joins le fichier, je pense que ce sera plus simple de visu.
onglet STLIV = fichier de départ
Feuil1 = fichier souhaité
Merci encore.
https://www.cjoint.com/?0JepjInhbSa
Au vu de ton fichier, modification pour la 1ere colonne + choix des feuilles
Sub transposition()
un = InputBox("Nom de la feuille à transposer ?")
deu = InputBox("Nom de la feuille où effectuer la transposition ?")
der = InputBox("N° de la dernière ligne à transposer ?")
lg = 2 'donc commencera à copier à partir de la ligne 2
For n = lg To der
a = a + 1
Sheets(deu).Cells(a, 1) = Sheets(un).Cells(n, 1).Value
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 2).Value
a = a + 1
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 3).Value
a = a + 1
a = a + 1
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 4).Value
a = a + 1
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 6).Value
a = a + 1
Next
End Sub
Sub transposition()
un = InputBox("Nom de la feuille à transposer ?")
deu = InputBox("Nom de la feuille où effectuer la transposition ?")
der = InputBox("N° de la dernière ligne à transposer ?")
lg = 2 'donc commencera à copier à partir de la ligne 2
For n = lg To der
a = a + 1
Sheets(deu).Cells(a, 1) = Sheets(un).Cells(n, 1).Value
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 2).Value
a = a + 1
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 3).Value
a = a + 1
a = a + 1
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 4).Value
a = a + 1
Sheets(deu).Cells(a, 2).Value = Sheets(un).Cells(n, 6).Value
a = a + 1
Next
End Sub
Excusez moi de présenter une solution mais...
Chiche! on fait un concours de rapidité sur 6500 lignes ?
Chiche! on fait un concours de rapidité sur 6500 lignes ?
Option Base 1
Sub reamenager()
Dim Derlig As Integer, Lig_in As Integer, T_in(), Pas As Byte
Dim T_out(), Lig As Byte
Dim Start As Single
'initialisations
Start = Timer
Application.ScreenUpdating = False
With Sheets("stliv")
Derlig = .Columns("B").Find("*", , , , , xlPrevious).Row
'mémorisation tableau initial
T_in = .Range("A2:F" & Derlig).Value
End With
'réaménagement
Pas = 1
Lig = 1
For Lig_in = 1 To UBound(T_in)
Pas = Pas + 6
ReDim Preserve T_out(2, Pas)
T_out(1, Lig) = T_in(Lig_in, 1)
T_out(2, Lig) = T_in(Lig_in, 2)
Lig = Lig + 1
T_out(2, Lig) = T_in(Lig_in, 3)
Lig = Lig + 2
T_out(2, Lig) = T_in(Lig_in, 4)
Lig = Lig + 2
T_out(2, Lig) = T_in(Lig_in, 6)
Lig = Lig + 1
Next
With Sheets(1)
.Range("D1").Resize(Lig, 2) = Application.Transpose(T_out)
End With
Application.ScreenUpdating = True
MsgBox "réaménagement effectué en: " & Timer - Start & " .secondes"
End Sub
Cordialement