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

VB.NET Discussion :

Copier puis insérer une ligne avec interop


Sujet :

VB.NET

  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2011
    Messages
    453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 453
    Points : 478
    Points
    478
    Par défaut Copier puis insérer une ligne avec interop
    Bonjour tout le monde,

    Vu que je ne capte pas grand chose avec VB et Interop (Il faut dire que la doc xml est très clair ) je me tourne une nouvelle fois vers vous.

    Donc comme l'indique le titre je souhaite copier puis insérer des lignes sur un fichier Excel. En fait j'ai un modèle de fichier, que j'utilise mais certaine catégorie pouvant évoluer avec le temps il faudra éventuellement que mon appli soit capable de modifier un peu ce modèle.

    Donc j'ai essayé ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
            Dim nbActiviteSupplementaire = 2
            Dim i = 0
            Dim index As String() = {"27", "28", "29", "30"}
            Dim numLigne As Integer = 31
            Do Until i = nbActiviteSupplementaire
                For Each s As String In index
                    maFeuille.Rows(s).copy(Destination:=maFeuille.Rows(numLigne))
                    numLigne += 1
                Next
                i += 1
            Loop
    Qui fonctionnait, mais il n'insère pas les lignes, il copie celle indiqué puis écrase celle à la ligne indiquée pour se mettre "par dessus".

    J'ai donc tenté ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
            Dim nbActiviteSupplementaire = 2
            Dim i = 0
            Dim index As String() = {"27", "28", "29", "30"}
            Dim numLigne As Integer = 31
            Do Until i = nbActiviteSupplementaire
                For Each s As String In index
                    maFeuille.Rows(numLigne).Insert(Excel.XlDirection.xlDown, maFeuille.Range(s).EntireRow)
                    numLigne += 1
                Next
                i += 1
            Loop
    Mais là j'ai une exception HResult

    Donc un p'tit coup de main ne serait pas de refus.

  2. #2
    Membre confirmé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2011
    Messages
    453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 453
    Points : 478
    Points
    478
    Par défaut
    Bon après beaucoup d'essais infructueux et de cheveux en moins voici la solution (Sûrement perfectible...) :

    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
     
           If dicoResultats.Keys.Count > 5 Then
                Dim nbActiviteSupplementaire = dicoResultats.Keys.Count - 5
                Dim i = 0
                Dim index As String() = {"27", "28", "29", "30"}
                Dim indexLigne As Integer = 31
                Do Until i = nbActiviteSupplementaire
                    For Each s As String In index
                        Dim maSelec = maFeuille.Rows(s).Copy
                        maFeuille.Rows(indexLigne).Insert(maSelec)
                        indexLigne += 1
                    Next
                    i += 1
                Loop
            End If

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

Discussions similaires

  1. Insérer une ligne avec la date au début d'un fichier
    Par bel09 dans le forum Shell et commandes GNU
    Réponses: 4
    Dernier message: 20/12/2013, 16h50
  2. Insérer une ligne avec une zone de texte
    Par coralie59 dans le forum Interfaces Graphiques
    Réponses: 1
    Dernier message: 25/02/2009, 19h17
  3. Insérer une ligne avec sed
    Par Olivier Regnier dans le forum Shell et commandes GNU
    Réponses: 7
    Dernier message: 28/06/2007, 14h08
  4. [VBA-E]Selectionner puis Insérer une ligne
    Par Xaphyr dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 27/03/2007, 18h43
  5. comment insérer une ligne avec CFile::Write
    Par gbardy dans le forum MFC
    Réponses: 2
    Dernier message: 10/08/2006, 10h19

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