html - 当按钮没有关联的 "name"时,使用 Excel VBA 单击 Internet Explorer 中的按钮

标签 html excel vba internet-explorer web-scraping

我正在尝试使用 excel 自动输入时间表中的值。时间表在网页上。 现在我可以加载页面,输入我的用户名和密码,然后自行输入时间表。请参阅下面的代码。

此时我需要点击一个按钮来打开子表单。我无法提前知道要打开多少个子表单。我知道当按钮有“名称”时如何点击它。但在这种情况下没有。所以我下面更新的代码使用一个循环来打开所有其他子表单。第一次成功,但当我再次这样做时

有人能告诉我如何确定页面中有多少个按钮以及如何点击每个按钮吗? 接下来,我将我目前拥有的代码放在它下面,我需要与之交互的页面的 HTML 代码。

Private Sub time_sheet_filling()

    Dim I As Long
    Dim IE As Object
    Dim doc As Object
    Dim objElement As Object
    Dim objCollection As Object

    ' Create InternetExplorer Object
    Set IE = CreateObject("InternetExplorer.Application")
    IE.Visible = True

    ' Send the form data To URL As POST binary request
    IE.navigate "http://timesheet.cccc.ca/timesheet/"

    ' Wait while IE loading...
    Do While IE.Busy
        Application.Wait DateAdd("s", 1, Now)
    Loop

        'Load the logon page
    Set objCollection = IE.Document.getElementsByTagName("input")
    I = 0
    While I < objCollection.Length
        If objCollection(I).Name = "txtUserName" Then
            ' Set text to enter
            objCollection(I).Value = "6666"
        End If
        If objCollection(I).Name = "txtPwd" Then
            ' Set text for password
            objCollection(I).Value = "password"
        End If
        If objCollection(I).Type = "submit" And objCollection(I).Name = "btnSubmit" Then ' submit button clicking
            Set objElement = objCollection(I)
        End If
        I = I + 1
    Wend

    objElement.Click    ' click button to load the form

    ' Wait while IE re-loading...
    Do While IE.Busy
        Application.Wait DateAdd("s", 1, Now)
    Loop

    ' Show IE
    IE.Visible = True  
Dim links, link
Dim n, j
Set links = IE.Document.getElementById("dgTime").getElementsByTagName("a")
n = links.Length  
For j = 0 To n - 1 Step 2
    links(j).Click
'I have some operations to be done will post another question for this
IE.Document.getElementById"DetailToolbar1_lnkBtnSave").Click              'save
IE.Document.getElementById"DetailToolbar1_lnkBtnCancel").Click            'close
Next



End Sub  

所以下面是 html 代码的摘录。我正在尝试单击在下面 html 代码的最后一行中编码的按钮

<table width="984" class="Grid" id="dgTime" border="1" rules="all" cellspacing="0">
  <tbody>
    <tr class="GridHeader">
    </tr>
    <tr class="GridItem">
    </tr>
    <tr class="GridItem">
      <td class="GridButtonColumn">
        <a href="javascript:__doPostBack('dgTime$_ctl2$_ctl0','')">
          <img src="images/toolbar/b_edit.gif">
        </a>
      </td  

Tx Tim 的答案。现在我可以选择第一个子表单按钮将其打开。

links(j).click   'j = 0 

然后我保存它,关闭并返回到主窗体。但是当我尝试做的时候

links(j).click   'j = 2 this time

我第二次收到运行时错误 70:权限被拒绝。任何善意的帮助将不胜感激。 问候

最佳答案

在蒂姆·威廉姆斯 (Tim Williams) 的热心帮助下,我终于弄清楚了最后遗漏的细节。这是下面的最终代码。

Private Sub Open_multiple_sub_pages_from_main_page()


Dim i As Long
Dim IE As Object
Dim Doc As Object
Dim objElement As Object
Dim objCollection As Object
Dim buttonCollection As Object
Dim valeur_heure As Object


' Create InternetExplorer Object
Set IE = CreateObject("InternetExplorer.Application")
' You can uncoment Next line To see form results
IE.Visible = True

' Send the form data To URL As POST binary request
IE.navigate "http://webpage.com/"

' Wait while IE loading...
While IE.Busy
        DoEvents
Wend


Set objCollection = IE.Document.getElementsByTagName("input")

i = 0
While i < objCollection.Length
    If objCollection(i).Name = "txtUserName" Then
        ' Set text for search
        objCollection(i).Value = "1234"
    End If
    If objCollection(i).Name = "txtPwd" Then
        ' Set text for search
        objCollection(i).Value = "password"
    End If

    If objCollection(i).Type = "submit" And objCollection(i).Name = "btnSubmit" Then ' submit button if found and set
        Set objElement = objCollection(i)
    End If
    i = i + 1
Wend
objElement.Click    ' click button to load page

' Wait while IE re-loading...
While IE.Busy
        DoEvents
Wend

' Show IE
IE.Visible = True
Set Doc = IE.Document

Dim links, link

Dim j As Integer                                                                    'variable to count items
j = 0
Set links = IE.Document.getElementById("dgTime").getElementsByTagName("a")
n = links.Length
While j <= n                                    'loop to go thru all "a" item so it loads next page
    links(j).Click
    While IE.Busy
        DoEvents
    Wend
    '-------------Do stuff here:  copy field value and paste in excel sheet.  Will post another question for this------------------------
    IE.Document.getElementById("DetailToolbar1_lnkBtnSave").Click              'save
    Do While IE.Busy
        Application.Wait DateAdd("s", 1, Now)                                   'wait
    Loop
    IE.Document.getElementById("DetailToolbar1_lnkBtnCancel").Click            'close
    Do While IE.Busy
        Application.Wait DateAdd("s", 1, Now)                                   'wait
    Loop
    Set links = IE.Document.getElementById("dgTime").getElementsByTagName("a")
    j = j + 2
Wend    
End Sub

关于html - 当按钮没有关联的 "name"时,使用 Excel VBA 单击 Internet Explorer 中的按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28153744/

相关文章:

用于在图像旁边居中垂直文本的 HTML + CSS

html - 是否可以创建仅 CSS 的 Accordion ?

javascript - 如何在 jQuery 脚本中将 .val() 内的某些单词设为粗体?

excel - 通过测试 ID 从 Excel 执行 alm 中的测试用例

jquery - 如何使用 VBA 触发更新网页的事件?

VBA 评估功能不起作用。错误2015

Excel VBA - 如何根据丢失的工作表重命名工作表

excel - 返回 Excel 用户窗体中组中选定的单选按钮

javascript - 在 Bootstrap 3 中,如何将下拉列表中的列表项设置为一级菜单项,并且仅在 xs 屏幕尺寸上设置?

excel - 如何在 Excel 中将 hh :mm:ss. 000 转换为毫秒?