Macro Excel:difficulté parcours d'un tableau

benours Messages postés 930 Statut Membre -  
benours Messages postés 930 Statut Membre -
Bonjour,

Je cherche à réaliser une macro sous Excel 2003 pour pouvoir organiser les données récupérer dans un fichier TXT. Dans ce fichier, les données sont organisées par ligne, regroupées quatre par quatre que je souhaiterais ranger sur une ligne et quatre colonnes.

En terme d'algo (si je puis dire), il s'agit de (position initiale en A1):

descendre en A2 et couper la cellule, monter en B1 et la coller,
descendre en A3 et couper la cellule, monter en C1 et la coller,
descendre en A4 et couper la cellule, monter en D1 et la coller,
supprimer les lignes 2/3/4,
se placer en A2 (A1+1),

descendre en A3 (A2+1) et couper la cellule, monter en B2 (B1+1) et la coller,
...

J'ai donc tenté de réaliser cette macro en m'arrêtant à "se placer en A2" en pensant qu'elle reproduirait les 4 actions précédentes "translatées" d'une ligne vers le bas. En réalité, la macro repart à chaque fois de A1 et supprime donc toutes les données à part celles de la première ligne.

J'ai jeté un oeil au VBA (modifier la macro) mais je n'y connais rien. J'ai quelques notions d'algo et de programmation mais je n'ai aucune maitrise de ce langage.

Existe-t-il un moyen de réaliser ma macro sans passer par l'édition en VBA?
Si la réponse est non, pourriez-vous m'orienter sur la manière de programmer ça?
On pourrait commencer par écrire "Hello" ligne par ligne... ça suffirait pour me permettre de faire le reste.

Merci d'avance!

4 réponses

  1. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 772
     
    Bonjour,
    Pas à pas :
    1- ouvrez votre classeur Excel
    2- Sur la feuille concernée, tapez ALT+F11 --> une fenêtre Visual Basic s'ouvre
    3- Insertion/Modules
    4- copiez collez ce code :

    Sub rangement()
    'déclaration des variables, i pour la boucle et derlig fin de boucle
    Dim i, derlig As Integer
    'derlig = nombre de lignes de la colonne A divisé par 4
    derlig = CInt(Range("A65536").End(xlUp).Row / 4)
    'initialise la boucle 
    For i = 1 To derlig
    'la syntaxe Cells(ligne, colonne) est facilement accessible
        Cells(i, 2).Value = Cells(i + 1, 1).Value
        Cells(i, 3).Value = Cells(i + 2, 1).Value
        Cells(i, 4).Value = Cells(i + 3, 1).Value
    'ici on supprime les lignes entières...
        Range(Cells(i + 1, 1), Cells(i + 3, 1)).EntireRow.Delete
    Next
    End Sub

    5- fermez la fenêtre visual Basic
    6- pour lancer la macro : ALT + F8, choisir "rangement" et Exécuter...

    J'ai annoté le code pour une meilleure compréhension, n'hésitez pas à poser vos questions.
    Il doit y avoir plus simple, en tout cas plus rapide. C'est assez long, j'ai testé avec 10 000 lignes...
    Dis...
    0
  2. Bidouilleu_R Messages postés 1209 Statut Membre 296
     
    un moyen sans utiliser le vba .... à la main peut-être :-(
    un petit code pour débuter en vba....
    un bon exemple concret aidera davantage.

    à partir de la feuille du classeur
    Alt F11 ( editeur VBA)
    click sur
    insertion /module
    dans la feuille créée copie et colle le code ci-dessous.

    puis avec la touche F8 exécute le en pas à pas
    tu verras ce qui se passe.
    A+

    Sub transposition()
    Dim NbLig as long
    Dim I as integer
    
    Sheets("feuil1").Select  ' à adapter
    NbLig = Range("a1").CurrentRegion.Rows.Count
    
    For I = 0 To nblig Step 4
        Range("A1").Offset(I + 1, 0).Resize(3, 1).Select
        Selection.Copy
        Range("A1").Offset(I, 1).Resize(1, 3).Select
        Selection.PasteSpecial Paste:=xlPasteAll, Operation:=xlNone, SkipBlanks:= _
            False, Transpose:=True
    Next
    ' on efface la ligne entière en controlant
    'les vides de la colonne B
    For I = 1 To NbLig
        If IsEmpty(Cells(I, 2)) Then
        Rows(I).Delete
        I = I - 1
        End If
    Next I
    
    
    End Sub
    0
    1. Bidouilleu_R Messages postés 1209 Statut Membre 296
       
      Salut Pijaku,
      on s'est croisé je crois..
      ta remarque sur la longueur ( nombre de ligne est judicieuse)
      on peut accélérer mon code comme ça

      Sub transposition()
      Dim NbLig As Long
      Dim I As Long

      Sheets("feuil1").Select ' à adapter
      NbLig = Range("a1").CurrentRegion.Rows.Count
      Application.ScreenUpdating = False
      For I = 0 To NbLig Step 4
      Range("A1").Offset(I + 1, 0).Resize(3, 1).Select
      Selection.Copy
      Range("A1").Offset(I, 1).Resize(1, 3).Select
      Selection.PasteSpecial Paste:=xlPasteAll, Operation:=xlNone, SkipBlanks:= _
      False, Transpose:=True
      Next
      ' on efface la ligne entière en controlant
      'les vides de la colonne B
      Range("A1").Select

      For I = 1 To NbLig
      If IsEmpty(Cells(I, 2)) And Not IsEmpty(Cells(I, 1)) Then
      Rows(I).Delete
      I = I - 1

      End If
      Next I
      Application.ScreenUpdating = True
      Range("A1").Select
      End Sub
      0
    2. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 772
       
      Salut Bidouilleu,
      Oui nos réponses se sont croisées.
      Ma remarque sur la lenteur vient de ce que je crois cette procédure réalisable avec une variable tableau... Ca serait certainement plus rapide. Malheureusement, je ne suis pas assez câlé pour ça. Je vais néanmoins essayer.
      0
  3. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 772
     
    Version "rapide" si 25000 lignes :
    Sub repartition_par_tablo()
    Dim tablo() As String
    Dim I, j, k, derlig As Integer
    derlig = Range("A65536").End(xlUp).Row
        ReDim tablo(derlig)
    For I = 1 To UBound(tablo)
        tablo(I) = Cells(I, 1).Value
    Next
    k = 1
    derlig = CInt(derlig / 4)
    For I = 1 To derlig
        For j = 1 To 4
            Cells(I, j).Value = tablo(k)
            k = k + 1
        Next j
    Next I
    I = Range("B65536").End(xlUp).Row
    j = Range("A65536").End(xlUp).Row
    Range(Cells(I, 1), Cells(j, 1)).EntireRow.Delete
    End Sub
    --
    Cordialement,
    -- Tout problème à sa solution. S'il n'y a pas de solution, ou est le problème? --
    0
  4. benours Messages postés 930 Statut Membre 109
     
    Super! Merci beaucoup.

    J'ai d'autres sujets qui sont venus s'intercaler avant celui-ci mais je ne manquerai pas de revenir vous faire part de mes commentaires dès que j'aurais trouvé le temps de mettre ce code en oeuvre.

    Ce qui est sur, c'est qu'il m'était impossible d'improviser! Merci encore.

    Bonne journée.
    0