我正在尝试与具有大型表格的网站进行交互:
<table id="tblID" cellspacing="1" cellpadding="0" border="0" width="100%">
<tbody><tr valign="top" align="left">
<td colspan="6" height="10"></td>
</tr>
<tr><td bgcolor="#666666" height="1" colspan="6"><img src="img.gif" width="1" height="1" border="0"></td></tr>
<tr class="GridHeader" valign="top" align="left">
<td width="60"><b>Select</b></td>
<td width="210" colspan="2"><b>Account Type</b></td>
<td width="160" colspan="2"><b>Number</b></td>
<td width="200"><b>Account known as</b></td>
</tr>
<tr align="left" valign="middle">
<td class="normal"><input type="radio" id="radButton" name="radButton" value="1233399,1515636"></td>
<td class="normal">ACCTYPE</td>
<td class="normal" width="10"> </td>
<td class="normal">ACCNUMBER</td>
<td class="normal" width="10"> </td>
<td class="normal">ACCNAME</td>
</tr>
<tr align="left" valign="top">
<td height="1" colspan="6" bgcolor="#cccccc"><img src=".img.gif" width="1" height="1" border="0"></td>
</tr>
<tr align="left" valign="middle">
<td class="normal"><input type="radio" id="radButton" name="radButton" value="2263763,2777747"></td>
<td class="normal">ACCTYPE</td>
<td class="normal" width="10"> </td>
<td class="normal">ACCNUMBER</td>
<td class="normal" width="10"> </td>
<td class="normal">ACCNAME</td>
</tr>
这会持续数百行。
我的代码的目的是根据ACCNUMBER搜索行,并选择相关的单选按钮。我的代码执行此操作,但需要很长时间才能执行此操作。
到目前为止,我的ruby代码是:require 'watir'
require 'nokogiri'
html = browser.html
doc = Nokogiri::HTML(html)
*csv import and loop stuff*
bkacc = CSV[0]
*nokogiri go fast!*
rows = doc.css("table[id='tblID'] tbody tr")
rows.each do |row|
target = row.text[bkacc]
if !target.nil?
cells = row.css("td[class='normal']")
@pushme = cells[0].css('input')[0]['value']
end
end
*watir goes slow*
browser.table(:id,"tblMaintenance").tbody.trs(:valign,"middle").find do |tr|
temp = tr.td(index: 0).radio(:id => "radButton").attribute_value("value")
if temp == @pushme
tr.td(index: 0).radio(:id => "radButton").set
break
end
end
*other commands and loop to next line in csv*
我想要推送的按钮值的发现非常快,使用nokogiri,但是一旦找到,使用:要查找的值并使用watir设置按钮非常慢。
我的问题是;我怎样才能加快速度呢?我想也许通过使用机械化我可以,但语法逃脱了我。我对Ruby仍然很陌生,所以可能缺少一些基本知识。
答案 0 :(得分:0)
假设id和value属性的组合对于每个单选按钮都是唯一的,您可以直接找到单选按钮。整个Watir循环可以被替换为:
browser.radio(:id => "radButton", :value => @pushme).set
或者,我会尝试使用以下内容替换两个循环。找到行将比Nokogiri方法慢一点,但代码会更简单。
row = browser.table(id: 'tblID').tr(text: /#{bkacc}/)
row.radio.set