【发布时间】:2012-02-05 14:50:03
【问题描述】:
我要测试的是table元素是否存在?如果没有桌子,那么我只想让脚本结束。但是,如果有一个表格,我想将其输出到 excel。
脚本正在测试两个 url:
http://www.mycounciltax.org.uk/results?postcode=EX99AE&search=Search
http://www.mycounciltax.org.uk/results?postcode=CV56bz&search=Search
第一个 url 显示一个没有 html 表格的网页,第二个显示一个包含 html 表格元素的网页。
我尝试将以下脚本放在一起,但我认为这是不正确的。我确信我在测试表格元素时犯了一个错误。
if browser.table.trs.collect {|tr| [tr[0].text, tr[1].text, tr[2].text]}.exists?
then content = browser.table.trs.collect {|tr| [tr[0].text, tr[1].text, tr[2].text]}
如果你从下面的脚本中删除上面的代码,它会运行,但是当它找不到 html 表时会崩溃。
require "watir-webdriver"
browser = Watir::Browser.new :ff
browser.goto "http://www.mycounciltax.org.uk/results?postcode=CV56BZ&search=Search"
if browser.table.trs.collect {|tr| [tr[0].text, tr[1].text, tr[2].text]}.exists?
then content = browser.table.trs.collect {|tr| [tr[0].text, tr[1].text, tr[2].text]}
require 'win32ole'
application = WIN32OLE.new('Excel.Application')
application.visible = TRUE
workbook = application.Workbooks.Add();
worksheet = workbook.Worksheets(1);
worksheet.visible
row = 1; column = 0
content.each do |array|
array.each do |element|
worksheet.Cells(1,1).offset(row,column).value = element #.offset(row,column)
column += 1
end
row += 1
column = 0
end
else end
browser.goto "http://www.mycounciltax.org.uk/results?postcode=EX99AE&search=Search"
if browser.table.trs.collect {|tr| [tr[0].text, tr[1].text, tr[2].text]}.exists?
then content = browser.table.trs.collect {|tr| [tr[0].text, tr[1].text, tr[2].text]}
require 'win32ole'
application = WIN32OLE.new('Excel.Application')
application.visible = TRUE
workbook = application.Workbooks.Add();
worksheet = workbook.Worksheets(1);
worksheet.visible
row = 1; column = 0
content.each do |array|
array.each do |element|
worksheet.Cells(1,1).offset(row,column).value = element #.offset(row,column)
column += 1
end
row += 1
column = 0
end
else end
我打算立即运行上述代码。谁能指出我哪里出错了?我是 ruby 和 watir 的新手 :-)。
非常感谢。
【问题讨论】:
标签: ruby watir watir-webdriver