Ruby最快的方式来选择大表中的按钮

时间:2018-03-19 00:23:25

标签: ruby nokogiri mechanize watir

我正在尝试与具有大型表格的网站进行交互:

    <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">&nbsp;</td>
                                    <td class="normal">ACCNUMBER</td>
                                    <td class="normal" width="10">&nbsp;</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">&nbsp;</td>
                                    <td class="normal">ACCNUMBER</td>
                                    <td class="normal" width="10">&nbsp;</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仍然很陌生,所以可能缺少一些基本知识。

1 个答案:

答案 0 :(得分:0)

假设id和value属性的组合对于每个单选按钮都是唯一的,您可以直接找到单选按钮。整个Watir循环可以被替换为:

browser.radio(:id => "radButton", :value => @pushme).set

或者,我会尝试使用以下内容替换两个循环。找到行将比Nokogiri方法慢一点,但代码会更简单。

row = browser.table(id: 'tblID').tr(text: /#{bkacc}/)
row.radio.set