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 :

Ecrire sur la première ligne vide


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    11
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 11
    Points : 7
    Points
    7
    Par défaut Ecrire sur la première ligne vide
    bonjour,
    j'avais le même probleme que cobra85 dans cette discussion et votre réponse m'a permis d'avancer; malheureusement, j'ai encore un souci, quand j'applique cette macro sur une base de données que j'avais déjà et qui contient 64 lignes, la prochaine s'insère à la ligne 132 . pouvez-vous m'aidez SVP

  2. #2
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 546
    Points
    15 546
    Par défaut
    Supprime tes ligne 65 à 132. Tu as forcément au moins un espace ou "une crotte" dans une cellule.
    Avec la syntaxe citée pour rechercher la dernière ligne, tu n'as pas à enregistrer le fichier après suppression des lignes (suggéré dans ma réponse à ton mp)
    A+

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    11
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 11
    Points : 7
    Points
    7
    Par défaut
    merci pour ton aide. j'ai supprimé les lignes et ça fonctionne, seulement, maintenant, mon formulaire se vide à chaque transposition. que faire?

  4. #4
    Membre habitué
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2006
    Messages
    128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2006
    Messages : 128
    Points : 168
    Points
    168
    Par défaut
    bonjour
    j'espere que t'as pas supprimé avec du code vba !!!!!
    montres nous ton bout de code stp pour voir mieux

  5. #5
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    Une autre solution que Range("A1").End(xlUp).Row qui peut etre pratique dans certains cas (comme le tiens apparemment).
    C'est d'utiliser une boucle qui vérifie si sur une colonne obligatoire la cellule est vide

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    dim i as long
     
    do while range("A" & i).value<>""
       i=i+1
    loop

  6. #6
    Futur Membre du Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    11
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 11
    Points : 7
    Points
    7
    Par défaut
    merci pour vos réponses. non Getule, je n'ai pas suppimer le code vba, seulement, a chaque enregistrement, je dois "reparamétrer" la macro et le bouton qui y est affecté car tout disparait. je joins la macro utilisé à laquelle je n'ai porter aucune modif
    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
    Sub transpose_dans_tableau_V02()
        Dim ligne_active_base As Integer
     
        Worksheets("Formulaire").Range("B1:B72").Copy
     
        If Worksheets("BD RESIDENTS").Range("A1") = "" Then
            ligne_active_base = 1
            Else
            ligne_active_base = Worksheets("BD RESIDENTS"). _
                Range("A65536").End(xlUp).Row + 1
        End If
     
        'Collage avec transposition'
        Worksheets("BD RESIDENTS").Range("A" & ligne_active_base). _
            PasteSpecial Paste:=xlPasteAllExceptBorders, _
            Operation:=xlNone, SkipBlanks:=False, Transpose:=True
     
        'Rendre vierge le formulaire'
        Worksheets("Formulaire").Range("B1:B72").ClearContents
        'Désactive le mode copier/coller
        Application.CutCopyMode = False
    End Sub

  7. #7
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 546
    Points
    15 546
    Par défaut
    Citation Envoyé par jfontaine Voir le message
    Une autre solution que Range("A1").End(xlUp).Row qui peut etre pratique dans certains cas (comme le tiens apparemment).
    C'est d'utiliser une boucle qui vérifie si sur une colonne obligatoire la cellule est vide
    Risquée, la méthode ! Si tu as une cellule vide dans la colonne A, tu effaces toutes les lignes du dessous qui peuvent-être renseignées.

  8. #8
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    C'est pour ca que j'ai écrit
    sur une colonne obligatoire

  9. #9
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 546
    Points
    15 546
    Par défaut
    Hello Jfontaine,
    Comme je n'avais pas compris le sens de "colonne obligatoire", je vais te taquiner
    Dans ce cas-là, tu suggèrerais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    dim NoLigne as long, NoColAconserver as byte
    do while Cells(NoLigne, NoColAconserver).value <> ""
       NoLigne = NoLigne + 1
    loop

    Je sais, je suis un affreux

    Vanille, es-tu sûr que ta colonne A est renseignée ? Pour cette ligne, tu dois adapter la bonne colonne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                Range("A65536").End(xlUp).Row + 1
    A+

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. Réponses: 2
    Dernier message: 12/10/2014, 16h03
  3. Problème sur sélection de la première ligne vide
    Par atk_49 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 02/12/2013, 12h16
  4. Réponses: 13
    Dernier message: 11/11/2008, 13h45
  5. Remplir la première ligne vide
    Par Azounet1529 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 18/07/2007, 10h15

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