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 :

Pilotage de IE depuis excel: reperer et cocher une chexbox.


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier Avatar de biggione
    Inscrit en
    Juillet 2006
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 99
    Points : 91
    Points
    91
    Par défaut Pilotage de IE depuis excel: reperer et cocher une chexbox.
    je voudrais savoir commvoici mon problème:
    je pilote IE depuis excel.

    j'ai dans une page web un tableau contenant des infos. (données entourée par <td> et </td>).
    j'ai codé en vba un code qui me trouve dans la page web les infos que je retrouve dans ma page excel.
    mais dans cette page, la première colonne du tableau contient une checkbox.
    voilà se que je souhaiterai faire:

    pour chaque donnée retrouvée dans le fichier j'aimerai savoir à quelle ligne du tableau elle se situe pour pouvoir ensuite cocher automatiquement la checkbox correspondante apparamment la checkbox est crée dans chaque ligne par :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <input type="checkbox" name="Selected" value="259649">
    Cette ligne est toujours la meme pour chaque ligne, seul la valeur de value change.

    Donc voilà le problème: comment repérer la ligne ou se situe le mot trouvé pour pouvoir cocher la chexbox correspondante?

    Une idée?

  2. #2
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Points : 20 147
    Points
    20 147
    Par défaut
    bonjour

    j'espere que cet exemple pourra t'aider


    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
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    Sub piloterPageHTML()
        'nécéssite d'activer les références
        'Microsoft HTML Objects Library
        'et
        'Microsoft Internet Controls
     
        Dim IE As InternetExplorer
        Dim maPageHtml As HTMLDocument
        Dim Helem As IHTMLElementCollection
        Dim i As Integer
     
        Set IE = CreateObject("InternetExplorer.Application")
        IE.Visible = True
     
        IE.navigate "http://www.leSite.html"
            Do Until IE.readyState = READYSTATE_COMPLETE
            DoEvents
        Loop 'attend la fin du chargement
     
       Set maPageHtml = IE.document
       Set Helem = maPageHtml.getElementsByTagName("input")
     
        '(boucle pour identifier les checkbox)
        For i = 0 To Helem.Length - 1
        If Helem(i).getAttribute("type") = "checkbox" And _
            Helem(i).getAttribute("value") = "259649" Then Helem(i).Checked = True
     
        Exit For
        Next i
     
        '2eme exemple à tester
        For i = 0 To Helem.Length - 1
        If Helem(i).getAttribute("type") = "checkbox" And _
            Helem(i).getAttribute("name") = "selected" And _
            Helem(i).getAttribute("value") = "259649" Then Helem(i).Checked = True
     
        Exit For
        Next i
     
    End Sub


    bonne journée
    michel

  3. #3
    Membre régulier Avatar de biggione
    Inscrit en
    Juillet 2006
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 99
    Points : 91
    Points
    91
    Par défaut
    ton exemple m'eclairci un peu mais le truc c que je t'ai donné un exemple de chexbox sur ma page et que moi celle que je recherche, je ne sais rien dessus. je sais juste qu'elle se trouve dans la meme ligne du tableau sur ma page HTML donc c là le pb, comment la retrouver pour la checker ensuite?

    g penser compter les balises <tr> ou un truc du genre mais n'y a t'il pas plus simple du genre récupérer les coordonnées ligne, colonne du mot trouvé puis ensuite cocher la chexbox se trouvant sur la meme ligne?

    C'est possible ou pas? en tout cas j'ai cherché et g rien trouvé mais je pense que cela doit etree possible.

  4. #4
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Points : 20 147
    Points
    20 147
    Par défaut
    rebonjour

    dans ce cas, si la page html est correctement structurée, tu pourrais te baser sur l'index des lignes et colonnes dans le tableau et l'index du checkbox Helem(i)


    pour boucler sur les cellules d'un tableau html :

    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
    31
    32
    Sub Importer_tableauPageWeb()
        'http://www.developpez.net/forums/viewtopic.php?p=1987826#1987826
        '
        'activer la reference Microsoft HTML Objects Library
        'activer la reference Microsoft Internet Controls
        Dim IE As InternetExplorer
        Dim maPageHtml As HTMLDocument
        Dim Htable As IHTMLElementCollection
        Dim maTable As IHTMLTable
        Dim j As Integer, i As Integer
     
        Set IE = CreateObject("InternetExplorer.Application")
        IE.Visible = True
     
        IE.navigate "http:\\leSite.htm"
        Do Until IE.readyState = READYSTATE_COMPLETE
        DoEvents
        Loop
     
        Set maPageHtml = IE.document
        Set Htable = maPageHtml.getElementsByTagName("table") 'objet type table
        Set maTable = Htable(0) 'premier tableau dans la page Web
     
        'boucle sur toutes les lignes du tableau
        For i = 1 To maTable.Rows.Length
            'boucle sur les cellules dans chaque ligne
            For j = 1 To maTable.Rows(i - 1).Cells.Length
                Cells(i, j) = maTable.Rows(i - 1).Cells(j - 1).innerText
            Next j
        Next i
     
    End Sub


    difficile de répondre de façon plus détaillée sans voir la structure de la page


    bonne journée
    michel

  5. #5
    Membre régulier Avatar de biggione
    Inscrit en
    Juillet 2006
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 99
    Points : 91
    Points
    91
    Par défaut
    je sais que c un peu compliqué à comprendre sans voir mais bon je vais essayer de me débrouiller avec le code que tu m'a envoyé.

    je v un peu potassé tout ca puis je reviendrai dire où j'en suis d'ici quelque temps.


    Mais si d'autre veulent me laisser un message sur le sujet n'hésitez pas.

    Merci en tout cas.

  6. #6
    Membre régulier Avatar de biggione
    Inscrit en
    Juillet 2006
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 99
    Points : 91
    Points
    91
    Par défaut
    merci ca marche!!

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

Discussions similaires

  1. [XL-2003] Pilotage publipostage depuis excel : choisir les destinataires
    Par mazdav1 dans le forum Excel
    Réponses: 7
    Dernier message: 21/08/2013, 15h46
  2. Pilotage ACCESS depuis Excel
    Par Nako_lito dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 25/09/2009, 13h49
  3. Réponses: 0
    Dernier message: 13/11/2008, 23h47
  4. Pilotage entête word depuis excel
    Par hitmax dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 05/08/2008, 08h11
  5. Pilotage entête word depuis excel
    Par hitmax dans le forum VBA Word
    Réponses: 4
    Dernier message: 05/08/2008, 08h04

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