为什么 "get Elements By Name" 不工作?
Why isn't "get Elements By Name" working?
我对编程还很陌生。有人可以帮我弄这个吗?它总是在 getElementsByName 行崩溃,无法找出原因..
Option Explicit
Public Declare PtrSafe Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As LongPtr) 'For 64 Bit Systems
Sub getVerb()
Dim IE As Object ', objShellWindows As Object
Dim verb As String, strWebPath As String
strWebPath = "http://www.conjugation.org/"
verb = "querer"
'Navigate to page
'----------------
Set IE = CreateObject("InternetExplorer.Application")
With IE
.Visible = True
.Navigate strWebPath
End With
'Wait for page
Do While IE.Busy
Sleep 250
DoEvents
Loop
'Fill out
'---------
'Enter verb
'<input type="text" size="25" name="word">
IE.document.getElementsByName("word")(0).Value = verb
'Set to List
'<input type="radio" name="rb1" value="list">
IE.document.getElementsByName("rb1")(0).Value = "list"
'Press Button Conjugate
'<input type="submit" name="B1" value="Conjugate">
IE.document.getElementByName("B1").Click
'TODO: extract info
'Exit IE
'--------
IE.Quit
Set IE = Nothing
End Sub
当我使用诸如 HTML(或 JSON 之类的分层数据结构时,我发现自己很容易因为假设我正在处理哪个数据元素而感到困惑。如果我像您所做的那样开始堆叠多层次参考(并且我已经看到并完成了比这更深的层次),则尤其如此。
所以我最常打开早期绑定:在这种情况下,转到工具-->参考并确保选中 Microsoft HTML 对象库。
然后,我将关卡解压为中间对象:
Dim nodeList As IHTMLElementCollection
Set nodeList = IE.document.getElementsByName("word")
nodeList.Item(0).Value = verb
这样我就可以使用 VBE 调试器并检查数据结构并建立信心,我正在使用我想要的确切数据元素和列表项(和子元素等)。
我能够对您的代码进行以下更改并使其适用于我:
Option Explicit
Public Declare PtrSafe Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As LongPtr) 'For 64 Bit Systems
Sub getVerb()
Dim IE As Object ', objShellWindows As Object
Dim verb As String, strWebPath As String
strWebPath = "http://www.conjugation.org/"
verb = "querer"
'Navigate to page
'----------------
Set IE = CreateObject("InternetExplorer.Application")
With IE
.Visible = True
.Navigate strWebPath
End With
'Wait for page
Do While IE.Busy
Sleep 250
DoEvents
Loop
'Fill out
'---------
'Enter verb
'<input type="text" size="25" name="word">
Dim nodeList As IHTMLElementCollection
Set nodeList = IE.document.getElementsByName("word")
nodeList.Item(0).Value = verb
'Set to List
'<input type="radio" name="rb1" value="list">
Set nodeList = IE.document.getElementsByName("rb1")
nodeList.Item(0).Value = "list"
'Press Button Conjugate
'<input type="submit" name="B1" value="Conjugate">
Set nodeList = IE.document.getElementsByName("B1")
nodeList.Item(0).Click
'TODO: extract info
'Exit IE
'--------
IE.Quit
Set IE = Nothing
End Sub
这是一个优化的脚本,它利用适当的页面加载等待,然后 css 选择器。 CSS selectors 是一种更快、更灵活的元素匹配方式。
我认为这也有助于干净利落的阅读。
[x=y]
例如[value=list]
是 attribute = value selectors
. The input
is a type
selector. These selectors are applied via querySelector
method of HTMLDocument
对象,return 是指定 css 选择器的 DOM 中的第一个匹配项。
Option Explicit
'VBE > Tools > References:
' Microsoft Internet Controls
Public Sub EnterInfo()
Dim ie As New InternetExplorer
Const VERB As String = "querer"
With ie
.Visible = True
.Navigate2 "http://www.conjugation.org/"
While .Busy Or .readyState < 4: DoEvents: Wend
With .document
.querySelector("input").Value = VERB 'first input tag element
.querySelector("[value=list]").Click '< first element with value attribute having value of list
.querySelector("[value=Conjugate]").Click '< first element with value attribute having value of Conjugate
End With
Stop '<= delete me later
.Quit
End With
End Sub
探索浏览器中的 css 选择器(显示 Chrome):
练习css选择器:
我对编程还很陌生。有人可以帮我弄这个吗?它总是在 getElementsByName 行崩溃,无法找出原因..
Option Explicit
Public Declare PtrSafe Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As LongPtr) 'For 64 Bit Systems
Sub getVerb()
Dim IE As Object ', objShellWindows As Object
Dim verb As String, strWebPath As String
strWebPath = "http://www.conjugation.org/"
verb = "querer"
'Navigate to page
'----------------
Set IE = CreateObject("InternetExplorer.Application")
With IE
.Visible = True
.Navigate strWebPath
End With
'Wait for page
Do While IE.Busy
Sleep 250
DoEvents
Loop
'Fill out
'---------
'Enter verb
'<input type="text" size="25" name="word">
IE.document.getElementsByName("word")(0).Value = verb
'Set to List
'<input type="radio" name="rb1" value="list">
IE.document.getElementsByName("rb1")(0).Value = "list"
'Press Button Conjugate
'<input type="submit" name="B1" value="Conjugate">
IE.document.getElementByName("B1").Click
'TODO: extract info
'Exit IE
'--------
IE.Quit
Set IE = Nothing
End Sub
当我使用诸如 HTML(或 JSON 之类的分层数据结构时,我发现自己很容易因为假设我正在处理哪个数据元素而感到困惑。如果我像您所做的那样开始堆叠多层次参考(并且我已经看到并完成了比这更深的层次),则尤其如此。
所以我最常打开早期绑定:在这种情况下,转到工具-->参考并确保选中 Microsoft HTML 对象库。
然后,我将关卡解压为中间对象:
Dim nodeList As IHTMLElementCollection
Set nodeList = IE.document.getElementsByName("word")
nodeList.Item(0).Value = verb
这样我就可以使用 VBE 调试器并检查数据结构并建立信心,我正在使用我想要的确切数据元素和列表项(和子元素等)。
我能够对您的代码进行以下更改并使其适用于我:
Option Explicit
Public Declare PtrSafe Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As LongPtr) 'For 64 Bit Systems
Sub getVerb()
Dim IE As Object ', objShellWindows As Object
Dim verb As String, strWebPath As String
strWebPath = "http://www.conjugation.org/"
verb = "querer"
'Navigate to page
'----------------
Set IE = CreateObject("InternetExplorer.Application")
With IE
.Visible = True
.Navigate strWebPath
End With
'Wait for page
Do While IE.Busy
Sleep 250
DoEvents
Loop
'Fill out
'---------
'Enter verb
'<input type="text" size="25" name="word">
Dim nodeList As IHTMLElementCollection
Set nodeList = IE.document.getElementsByName("word")
nodeList.Item(0).Value = verb
'Set to List
'<input type="radio" name="rb1" value="list">
Set nodeList = IE.document.getElementsByName("rb1")
nodeList.Item(0).Value = "list"
'Press Button Conjugate
'<input type="submit" name="B1" value="Conjugate">
Set nodeList = IE.document.getElementsByName("B1")
nodeList.Item(0).Click
'TODO: extract info
'Exit IE
'--------
IE.Quit
Set IE = Nothing
End Sub
这是一个优化的脚本,它利用适当的页面加载等待,然后 css 选择器。 CSS selectors 是一种更快、更灵活的元素匹配方式。 我认为这也有助于干净利落的阅读。
[x=y]
例如[value=list]
是 attribute = value selectors
. The input
is a type
selector. These selectors are applied via querySelector
method of HTMLDocument
对象,return 是指定 css 选择器的 DOM 中的第一个匹配项。
Option Explicit
'VBE > Tools > References:
' Microsoft Internet Controls
Public Sub EnterInfo()
Dim ie As New InternetExplorer
Const VERB As String = "querer"
With ie
.Visible = True
.Navigate2 "http://www.conjugation.org/"
While .Busy Or .readyState < 4: DoEvents: Wend
With .document
.querySelector("input").Value = VERB 'first input tag element
.querySelector("[value=list]").Click '< first element with value attribute having value of list
.querySelector("[value=Conjugate]").Click '< first element with value attribute having value of Conjugate
End With
Stop '<= delete me later
.Quit
End With
End Sub
探索浏览器中的 css 选择器(显示 Chrome):
练习css选择器: