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 :

exporter des données vers un ficher créé [XL-2013]


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut exporter des données vers un ficher créé
    bonjour a tous .je reviens vers vous encore une fois parce que ce forum était toujours à l’écoute avec ses membres réactives . merci à vous
    j'ai un petit soucis avec mon code qu me lance un erreur d’exécution '9'. en fait je souhaite copier des lignes de la feuille DATA dont la colonne T est vide vers un autre ficher que je souhaite créer qui s'appel wb_sms_non_envoyes
    voici mon code :
    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
     
    Sub extract()
     
        Dim wb_sms_non_envoyes As Workbook
        Dim nbLignes As Integer
        Dim trig As Integer
     
        ' récupération nombre lignes non vides
        ' dans la page DATA pour extraire à partir de la ligne suivante
        nbLignes = Sheets("DATA").Range("T104").End(xlUp).Row
     
           Set wb_sms_non_envoyes = Workbooks.Add
     
        With wb_sms_non_envoyes
        .SaveAs Filename:=wb.Path & "wb_sms_non_envoyes" & ".xlsx"
     
        End With
     
        trig = 0
                ' boucle allant de 1 jusqu'à la dernière ligne non vide de la feuille DATA
                For x = 1 To nbLignes
                    ' si la cellule en T1 ... Tx est vide
                    ' alors on copie la ligne entière dans le fichier wb_sms_non_envoyes
                    If Sheets("DATA").Cells(x, 20).Value = "" Then
                        Sheets("DATA").Cells(x, 20).EntireRow.Copy Destination:=wb_sms_non_envoyes("Feuille1").Cells(nbLignes + 1, 1).Offset(trig, 0).EntireRow
                        trig = trig + 1
                    End If
                Next x
     
    End Sub
    quelqu'un pourra m'aider s'il vous plait ?
    merci par avance
    cordialement.

  2. #2
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut exporter des données vers un ficher crée
    finalement j'ai pu amélioré mon code il me crée bien un classeur mais il ne copie rien je vois pas d'où ça peut venir . quelqu'un pourrait m'aider svp je suis vraiment perdu
    ci dessous mon fichier si vous voulez jeter un œil
    merci par avance.
    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
     
    Sub extract()
     
        Dim WBsms As Workbook, LigMax As Integer, x As Integer
     
        ' récupération nombre lignes non vides dans la page DATA pour extraire à partir de la ligne suivante
        With ThisWorkbook.Sheets("DATA")
            nbLignes = .Range("T104").End(xlUp).Row
            Set WBsms = Workbooks.Add
            WBsms.SaveAs Filename:=ThisWorkbook.Path & "\wb_sms_non_envoyes.xlsx"
            ' boucle allant de 1 jusqu'à la dernière ligne non vide de la feuille DATA
                For x = 1 To LigMax
                    ' si la cellule en T1 ... Tx est vide alors on copie la ligne entière dans le fichier wb_sms_non_envoyes
                    If IsEmpty(.Cells(x, 20)) Then .Rows(x).Copy Destination:=WBsms.Sheets(1).Rows(LigMax + x)
                Next x
        End With
     
    End Sub
    Fichiers attachés Fichiers attachés

  3. #3
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    [....]
            nbLignes = .Range("T104").End(xlUp).Row
    [....]
                For x = 1 To LigMax
    Pour éviter ce type d'erreur, force la déclaration des variables avec un Option Explicit avant ton Sub ou en demandant qu'il soit placé par défaut : Outils > Options > Déclaration des variables obligatoire.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  4. #4
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut
    Citation Envoyé par Menhir Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    [....]
            nbLignes = .Range("T104").End(xlUp).Row
    [....]
                For x = 1 To LigMax
    Pour éviter ce type d'erreur, force la déclaration des variables avec un Option Explicit avant ton Sub ou en demandant qu'il soit placé par défaut : Outils > Options > Déclaration des variables obligatoire.
    bonjour. merci pour ta réactivité. j'ai fait ce que tu m'a demandé mais sans aucun changement

  5. #5
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par slakhdine Voir le message
    j'ai fait ce que tu m'a demandé mais sans aucun changement
    Je ne t'ai rien demandé de faire, j'ai juste indiquer où est l'erreur selon moi.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  6. #6
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut exporter des données vers un ficher crée
    Citation Envoyé par Menhir Voir le message
    Je ne t'ai rien demandé de faire, j'ai juste indiquer où est l'erreur selon moi.
    OUI justement merci beaucoup . mais il reste le même problème malheureusement.

  7. #7
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Quelle correction as-tu apporté à ton code ?
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  8. #8
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut exporter des données vers un ficher crée
    Citation Envoyé par Menhir Voir le message
    Quelle correction as-tu apporté à ton code ?
    j'ai rajouter juste l'option déclarations de variables obligatoire.

  9. #9
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Si tu n'as pas corrigé l'erreur que je t'ai indiqué, c'est sûr que ça ne peut pas fonctionner.

    De plus, obligé à la déclaration de variables, ça mettra un Option Explicit dans tous les nouveaux modules que tu créeras mais ça ne change rien aux modules existants.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  10. #10
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut
    Citation Envoyé par Menhir Voir le message
    Si tu n'as pas corrigé l'erreur que je t'ai indiqué, c'est sûr que ça ne peut pas fonctionner.

    De plus, obligé à la déclaration de variables, ça mettra un Option Explicit dans tous les nouveaux modules que tu créeras mais ça ne change rien aux modules existants.
    voici ce que j'ai rajouter sur le code :
    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
    Option Explicit
    Dim WBsms As Workbook, LigMax, nbLignes As Integer, x As Integer
     
    Sub extract()
     
        Dim WBsms As Workbook, LigMax, nbLignes As Integer, x As Integer
     
        ' récupération nombre lignes non vides dans la page DATA pour extraire à partir de la ligne suivante
        With ThisWorkbook.Sheets("DATA")
            nbLignes = .Range("T104").End(xlUp).Row
            Set WBsms = Workbooks.Add
            WBsms.SaveAs Filename:=ThisWorkbook.Path & "\wb_sms_non_envoyes.xlsx"
            ' boucle allant de 1 jusqu'à la dernière ligne non vide de la feuille DATA
                For x = 1 To LigMax
                    ' si la cellule en T1 ... Tx est vide alors on copie la ligne entière dans le fichier wb_sms_non_envoyes
                    If IsEmpty(.Cells(x, 20)) Then .Rows(x).Copy Destination:=WBsms.Sheets(1).Rows(LigMax + x)
                Next x
        End With
     
    End Sub

  11. #11
    Invité
    Invité(e)
    Par défaut
    Bonsoir,
    Et un filtre élaboré ?

  12. #12
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 764
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 764
    Points : 28 622
    Points
    28 622
    Billets dans le blog
    53
    Par défaut Avec la méthode AdvancedFilter
    Bonjour,
    A l'aide de la méthode AdvancedFilter (filtre élaboré)


    Exemple avec la plage de données source dans la feuille nommée db et qui exporte vers un nouveau classeur toutes lignes dont la colonne J (10ème colonne) est vide
    Pour que cela fonctionne, la liste de données doit avoir une ligne avec en-tête remplie et la première colonne remplie (pas d'autres liste à côté car la zone des critères se place 2 colonnes à droite de la dernière colonne de la source
    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
    22
    23
    24
    25
    26
    Sub t()
      ' Déclaration des variables et constantes
      Const shtSourceName As String = "db"  ' Nom de la feuille source
      Const ColumnToCompare As Integer = 10  ' N° de colonne à comparer
      Dim rngSource As Range
      Dim rngTarget As Range
      Dim rngCriteria As Range
      Dim Addr As String
      '
      Set rngSource = ThisWorkbook.Worksheets(shtSourceName).Range("A1").CurrentRegion
      Workbooks.Add '
      Set rngTarget = ActiveSheet.Range("A1")
      With rngSource
        Set rngCriteria = .Offset(0, .Columns.Count + 1).Resize(2, 1)
      End With
      Addr = Cells(2, ColumnToCompare).Address(RowAbsolute:=False)
      ' Rempli la zone des critères
      With rngCriteria
      .Item(1) = "_fx_": .Item(2).Formula = "=" & Addr & "=" & Chr(34) & Chr(34)
      End With
      ' Exportation
      rngSource.AdvancedFilter xlFilterCopy, rngCriteria, rngTarget
      ' EndOfProcess
      rngCriteria.Clear
      Set rngSource = Nothing: Set rngCriteria = Nothing: Set rngTarget = Nothing
    End Sub
    Il reste à sauver le nouveau classeur
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  13. #13
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par slakhdine Voir le message
    voici ce que j'ai rajouter sur le code :
    Regarde la partie de code que j'ai mis en réponse #3.
    Il n'y a pas un truc qui te dérange ? Je l'ai mis en gros et en gras.
    C'est évident quand même !
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  14. #14
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut exporter des données vers un ficher crée
    Citation Envoyé par Menhir Voir le message
    Regarde la partie de code que j'ai mis en réponse #3.
    Il n'y a pas un truc qui te dérange ? Je l'ai mis en gros et en gras.
    C'est évident quand même !
    Ah oui j'ai mal vu en fait , j'ai enlever LigMax du coup ça m'a donné ça :
    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
    Option Explicit
    Dim WBsms As Workbook, nbLignes As Integer, x As Integer
     
    Sub extract()
     
        Dim WBsms As Workbook, nbLignes As Integer, x As Integer
     
        ' récupération nombre lignes non vides dans la page DATA pour extraire à partir de la ligne suivante
        With ThisWorkbook.Sheets("DATA")
            nbLignes = .Range("T104").End(xlUp).Row
            Set WBsms = Workbooks.Add
            WBsms.SaveAs Filename:=ThisWorkbook.Path & "\wb_sms_non_envoyes.xlsx"
            ' boucle allant de 1 jusqu'à la dernière ligne non vide de la feuille DATA
                For x = 1 To nbLignes
                    ' si la cellule en T1 ... Tx est vide alors on copie la ligne entière dans le fichier wb_sms_non_envoyes
                    If IsEmpty(.Cells(x, 20)) Then .Rows(x).Copy Destination:=WBsms.Sheets(1).Rows(nbLignes + x)
                Next x
        End With
     
    End Sub

  15. #15
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut exporter des données vers un ficher crée
    Citation Envoyé par Philippe Tulliez Voir le message
    Bonjour,
    A l'aide de la méthode AdvancedFilter (filtre élaboré)


    Exemple avec la plage de données source dans la feuille nommée db et qui exporte vers un nouveau classeur toutes lignes dont la colonne J (10ème colonne) est vide
    Pour que cela fonctionne, la liste de données doit avoir une ligne avec en-tête remplie et la première colonne remplie (pas d'autres liste à côté car la zone des critères se place 2 colonnes à droite de la dernière colonne de la source
    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
    22
    23
    24
    25
    26
    Sub t()
      ' Déclaration des variables et constantes
      Const shtSourceName As String = "db"  ' Nom de la feuille source
      Const ColumnToCompare As Integer = 10  ' N° de colonne à comparer
      Dim rngSource As Range
      Dim rngTarget As Range
      Dim rngCriteria As Range
      Dim Addr As String
      '
      Set rngSource = ThisWorkbook.Worksheets(shtSourceName).Range("A1").CurrentRegion
      Workbooks.Add '
      Set rngTarget = ActiveSheet.Range("A1")
      With rngSource
        Set rngCriteria = .Offset(0, .Columns.Count + 1).Resize(2, 1)
      End With
      Addr = Cells(2, ColumnToCompare).Address(RowAbsolute:=False)
      ' Rempli la zone des critères
      With rngCriteria
      .Item(1) = "_fx_": .Item(2).Formula = "=" & Addr & "=" & Chr(34) & Chr(34)
      End With
      ' Exportation
      rngSource.AdvancedFilter xlFilterCopy, rngCriteria, rngTarget  
      ' EndOfProcess
      rngCriteria.Clear
      Set rngSource = Nothing: Set rngCriteria = Nothing: Set rngTarget = Nothing
    End Sub
    Il reste à sauver le nouveau classeur
    bonjour @philippe merci pour votre réponse et votre aide .votre code il marche bien sans aucun problème mais il me colle la première ligne je crois parce que je n'ai pas en-tête car les données sont extrait d'une base de donnée externe grâce a une requête .et que les 8 premiers colonnes moi je souhaite avoir toute la ligne

  16. #16
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 764
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 764
    Points : 28 622
    Points
    28 622
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    votre code il marche bien sans aucun problème mais il me colle la première ligne je crois parce que je n'ai pas en-tête car les données sont extrait d'une base de donnée externe grâce a une requête
    Comme je l'ai indiqué dans ma réponse IL FAUT que la première ligne ait des en-tête de colonnes (des titres) et en principe le résultat d'une requête le fait.

    et que les 8 premiers colonnes moi je souhaite avoir toute la ligne
    Je ne suis pas certain d'avoir compris ?
    L'exportation des colonnes est partielle ?
    Si c'est le cas cela signifie que la première ligne avait une ou des cellules vides. Voir ce que j'ai écrit plus haut.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  17. #17
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut exporter des données vers un ficher crée
    Citation Envoyé par Philippe Tulliez Voir le message
    Bonjour,

    Comme je l'ai indiqué dans ma réponse IL FAUT que la première ligne ait des en-tête de colonnes (des titres) et en principe le résultat d'une requête le fait.


    Je ne suis pas certain d'avoir compris ?
    L'exportation des colonnes est partielle ?
    Si c'est le cas cela signifie que la première ligne avait une ou des cellules vides. Voir ce que j'ai écrit plus haut.
    ou j'ai bien compris , merci pour tout ces précisions . je vais essayer de régler le problème d'en-têtes. pour le collage je souhaite copier que les lignes dont la colonne T est vide seulement.

  18. #18
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 764
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 764
    Points : 28 622
    Points
    28 622
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    pour le collage je souhaite copier que les lignes dont la colonne T est vide seulement.
    C'est exactement ce que fait la procédure que j'ai éditée mais à condition de respecter les consignes.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  19. #19
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2017
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2017
    Messages : 107
    Points : 68
    Points
    68
    Par défaut exporter des données vers un ficher crée
    Citation Envoyé par Philippe Tulliez Voir le message
    Bonjour,

    C'est exactement ce que fait la procédure que j'ai éditée mais à condition de respecter les consignes.
    merci infiniment pour votre aide, je serai très reconnaissant si vous pourriez jeter un œil sur mon ancien code ça me parait facile a adapter avec mon fichier si vous arrivez à me l’améliorer s'i vous plait

    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
    Option Explicit
    Dim WBsms As Workbook, nbLignes As Integer, x As Integer
     
    Sub extract()
     
        ' récupération nombre lignes non vides dans la page DATA pour extraire à partir de la ligne suivante
        With ThisWorkbook.Sheets("DATA")
            nbLignes = .Range("T104").End(xlUp).Row
            Set WBsms = Workbooks.Add
            WBsms.SaveAs Filename:=ThisWorkbook.Path & "\wb_sms_non_envoyes.xlsx"
            ' boucle allant de 1 jusqu'à la dernière ligne non vide de la feuille DATA
                For x = 1 To nbLignes
                    ' si la cellule en T1 ... Tx est vide alors on copie la ligne entière dans le fichier wb_sms_non_envoyes
                    If IsEmpty(.Cells(x, 20)) Then .Rows(x).Copy Destination:=WBsms.Sheets(1).Rows(nbLignes + x)
                Next x
        End With
     
    End Sub

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

Discussions similaires

  1. [DELPHI6] Comment exporter des données vers un fichier XML ?
    Par zoaax dans le forum Bases de données
    Réponses: 1
    Dernier message: 06/10/2006, 15h58
  2. exporter des données vers un fichier text
    Par JauB dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 30/07/2006, 21h36
  3. [Access 2002] Exporter des données vers une base Access 2.0
    Par SamLeChiseuji dans le forum Access
    Réponses: 27
    Dernier message: 01/06/2006, 11h41
  4. [En cours]Exporter des données vers Excel
    Par Muhad'hib dans le forum Contribuez
    Réponses: 2
    Dernier message: 12/01/2006, 14h25
  5. exporter des données vers EXCEL!
    Par JauB dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 25/11/2005, 15h13

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