Macros

Marimar -  
melanie1324 Messages postés 1561 Statut Membre -
Bonjour,
Comment je peux extraire des lignes et les mettres dans une autre feuille EXcel avec les Macro, en faite j'active la feuille 2 mais je ne sais pas comment affecté les lignes choisi dans la feuille2.

7 réponses

  1. melanie1324 Messages postés 1561 Statut Membre 156
     
    tout dépend de ton critère qui permet d'extraire les lignes!!
    0
  2. Marimar
     
    le critére utilisé est une date. j'ai des champs et j'ai envis de copier que les lignes ou lesheures sont inférieur à 19h et inférieur a 16h30.
    lors comment je peux ecrire ma macro pour pouvoir extraire que les lignes concernées et les mettres dans une autre feuille
    0
  3. melanie1324 Messages postés 1561 Statut Membre 156
     
    Bonjour,

    Pour pouvoir encore plus t'aider, la gestion des heures n'étant pas simple sous excel, il faudrait savoir sous quel format sont tes heures.

    En attendant, voici le début de ton code

    sub
    a=1
    i=1 'définit la première ligne ou tu as des données, si c'est à la ligne 2 mets i=2
    do while sheets("Nomfeuilleoutuastesheures").cells(i,1)<> "" 'cells(i,1) = cellule situe à ligne i et à la colonne 1, prends une colonne ou tu as toujours des données. Si c'est 2 mets cells(i,2)

    'la faut écrire ta condition :
    if sheets("Nomfeuilleoutuastesheures").cells(i,1)<="19h00" or sheets("Nomfeuilleoutuastesheures").cells(i,1)>="16h30" then ' cette conidtion ne fonctionne pas telle quelle il faut la modifier en fonction de tes données!!

    rows(i).copy
    sheets("Nomfeuilleoutuveuxmettredonnées").select
    cells(a,1).select
    activesheet.paste
    a=a+1
    end if
    i=i+1
    loop

    end sub
    0
    1. melanie1324 Messages postés 1561 Statut Membre 156
       
      pour bien définir ta condition, fais le d'abord avec une formule et vois si ca marche. Quand ca l'est incorpore la dans la macro.
      0
  4. Marimar
     
    Merci bcp Melanie pour ton aide en fait ta macro fonctionne trés bien avec un peu de modif da ma part. ESQ ta une idée pour pouvoir extraire les noms des champs.
    0
  5. Vous n’avez pas trouvé la réponse que vous recherchez ?

    Posez votre question
  6. melanie1324 Messages postés 1561 Statut Membre 156
     
    tout dépend de la ligne de ton intitule :

    sheets("nomoutuastesdonnées").select
    rows(numeroligneintitulé).copy
    sheets("nomoutuveuxcoller").select
    cells(1,1).select
    activesheet.paste
    0
    1. Marimar
       
      ok c bon, Merci mélanie ;)
      0
  7. Marimar
     
    j'ai décidé de travailler avec des sélections c'est a dire que ce qui est sélectionné dans mon fichier excel exécute la Macro( je m'explique ma macro ne dois pas parcourir tt le fichier excel mais elle doit parcourir ce que moi j'ai selectionné dans le fichir excel) ESq vous avez une idée comment je peux dire a la Macro ce qui est séléctionné.
    0
  8. melanie1324 Messages postés 1561 Statut Membre 156
     
    Bonjour,

    j'ai un début de réponse mais pour que ca marche, il faut que tu me confirmes cette idée.
    Ton filtre ne s'effectue que sur une seule colonne et toujours la même :

    Sub x()

    Sheets("Feuil1").Select 'Feuil1 est égale au nom de feuilles ou tu a sle filtre
    With Worksheets("Feuil1")
    If .AutoFilterMode Then
    With .AutoFilter.Filters(1) 'le chiffre 1 représente le numéro de colonne ou est ton filtre, si c'est en 2, mets 2
    If .On Then a = .Criteria1

    End With
    End If
    End With
    a = 2
    i = 1
    Do While Cells(i, 1) <> ""
    If Cells(i, 1).Value = a Then
    Rows(i).Copy
    Sheets("Feuil2").Select
    Cells(a, 1).Select
    ActiveSheet.Paste
    a=a+1
    End If
    Sheets("Feuil1").Select
    i = i + 1
    Loop

    End Sub
    0