如何获得水豚黄瓜中的元素集合

时间:2012-02-08 18:34:02

标签: xpath capybara

所有!

可能我有一张桌子

<tabel>
    <tr><td><input type=text/></td><td><input type=text/></td></tr>
    <tr><td><input type=text/></td><td><input type=text/></td></tr>
    <tr><td><input type=text/></td><td><input type=text/></td></tr>
    <tr><td><input type=text/></td><td><input type=text/></td></tr>
</table>

我希望用这样的黄瓜步骤定义填充它们

    table.hashes.each do |hash|
      within(:xpath,"//div[@id='cycle_form']/table/tr#{table.hashes.index(hash)}") do
        fill_in("schedule_of_working_new_cycle_attributes__day", :with => hash['day'])
        fill_in("schedule_of_working_new_cycle_attributes__hour", :with => hash['hour'])
        fill_in("schedule_of_working_new_cycle_attributes__hour_night", :with => hash['hour_night'])
      end
    end

我得@Unable找不到xpath“// div [@ id ='cycle_form'] / table / tr [0]”@

如何通过水豚获得元素集合?

1 个答案:

答案 0 :(得分:0)

这可能是XML的一个问题,所以假设它看起来像这样:

<div id="cycle_form">
    <table>
        <tr><td><input type="text"/></td><td><input type="text"/></td></tr>
        <tr><td><input type="text"/></td><td><input type="text"/></td></tr>
        <tr><td><input type="text"/></td><td><input type="text"/></td></tr>
        <tr><td><input type="text"/></td><td><input type="text"/></td></tr>
    </table>
</div>

这将有效:

//div[@id='cycle_form']/table/tr[1]

另一件事是XPath索引从1开始而不是0,所以你的原始查询不会有任何作用。 仔细检查输入XML并更正迭代的起始值,它应该可以工作。