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 :

Dupli lignes avec incrementation [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Octobre 2007
    Messages
    128
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 128
    Par défaut Dupli lignes avec incrementation
    Bonjour
    Je suis sous Excel 2010 / Win 7 et j'ai du mal à faire marcher mon macro ( format xlsm )

    Je voudrais traiter toutes les lignes d'un fichier ( voir mon fichier Exemple1.xlsx ) car je voudrais obtenir un autre fichier ( voir mon fichier Resultat1.xlsx ) avec des lignes dupliquées en x-1 fois ( selon Colonne G "SAP Qty" ) et avec incrementation ( Selon Colonne B "no d'ordre" ) comme dans mon fichier Resutlat1.xlsx
    mon probleme est que je ne peux pas prevoir le nombre totale de ligne
    Merci !

  2. #2
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    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
    Sub Dupliquer()
    Dim LastLig As Long, i As Long
    Dim Nb As Integer
     
    Application.ScreenUpdating = False
    With Worksheets("T_SAP_avec_Sub_0")
        LastLig = .Cells(.Rows.Count, 1).End(xlUp).Row
        For i = LastLig To 2 Step -1
            Nb = Val(.Range("G" & i).Value)
            If Nb >=2 Then
                .Rows(i).Copy
                .Rows(i & ":" & i + Nb - 2).Insert
                Application.CutCopyMode = False
            End If
        Next i
    End With
    End Sub

  3. #3
    Membre confirmé
    Inscrit en
    Octobre 2007
    Messages
    128
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 128
    Par défaut
    Ca marche ! Mais il manque l'incrementation en colonne B ( no d'ordre) qui reste toujours à 1 !

  4. #4
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    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
    Sub Dupliquer()
    Dim LastLig As Long, i As Long
    Dim Nb As Integer
     
    Application.ScreenUpdating = False
    With Worksheets("T_SAP_avec_Sub_0")
        LastLig = .Cells(.Rows.Count, 1).End(xlUp).Row
        For i = LastLig To 2 Step -1
            Nb = Val(.Range("G" & i).Value)
            If Nb >= 2 Then
                .Rows(i).Copy
                .Rows(i & ":" & i + Nb - 2).Insert
                Application.CutCopyMode = False
                With .Range("B" & i & ":B" & i + Nb - 1)
                    .Formula = "=ROW()+1-Row($B$" & i & ")"
                    .Value = .Value
                End With
            End If
        Next i
    End With
    End Sub

  5. #5
    Membre confirmé
    Inscrit en
    Octobre 2007
    Messages
    128
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 128
    Par défaut
    Ca marche ! il faut faire dans le sens inverse !

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

Discussions similaires

  1. Comment ecrire sur la meme ligne avec la commane ECHO
    Par juflata dans le forum Windows
    Réponses: 3
    Dernier message: 24/11/2015, 09h06
  2. Concaténer deux fichiers Ligne/Ligne avec SH
    Par guiltouf dans le forum Linux
    Réponses: 7
    Dernier message: 22/05/2007, 14h35
  3. Comment aller a la ligne avec la commande ECHO
    Par juflata dans le forum Windows
    Réponses: 3
    Dernier message: 23/06/2004, 17h11
  4. [FP]Tracer Une ligne avec Dev-pascal
    Par yffick dans le forum Turbo Pascal
    Réponses: 9
    Dernier message: 17/12/2003, 16h33
  5. supprimer une ligne avec cle etrangere
    Par BaBas dans le forum Langage SQL
    Réponses: 4
    Dernier message: 15/07/2003, 11h24

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