使用Watir获取表的整个列文本

Aks*_*s.. 2 ruby element watir

我知道使用以下代码我们可以在WATIR中获取整个行文本

# row 2 - entire text
table1 = browser.table(:id => "table")
puts table1[1].text
Run Code Online (Sandbox Code Playgroud)

我们怎么能得到像这样的整个列文本?

Jus*_* Ko 7

有一些内置方法可以帮助获取列数据,但Watir-Webdriver和Watir-Classic之间有所不同.

让我们假设我们正在使用该表:

<table>
  <tr>
    <td>1a</td>
    <td>1b</td>
  </tr>
  <tr>
    <td>2a</td>
    <td>2b</td>
  </tr>
</table>
Run Code Online (Sandbox Code Playgroud)

解决方案 - Watir-Webdriver和Watir-Classic

Table类有一个strings方法,它将表的文本作为2D数组返回.该数组是行,但您可以使用transpose它来将其作为列.

columns = browser.table(:id => "table").strings.transpose
p columns[0]
#=> ["1a", "2a"]
p columns[1]
#=> ["1b", "2b"]
Run Code Online (Sandbox Code Playgroud)

解决方案 - Watir-Classic

在Watir-Classic中,Table类还有一个内置column_values方法,这意味着您可以简单地执行:

p browser.table(:id => "table").column_values(0)
#=> ["1a", "2a"]
p browser.table(:id => "table").column_values(1)
#=> ["1b", "2b"]
Run Code Online (Sandbox Code Playgroud)

解决方案 - 迭代

您当然可以遍历每一行并收集每列中的单元格:

p browser.table(:id => "table").trs.collect{ |tr| tr[0].text }
#=> ["1a", "2a"]
p browser.table(:id => "table").trs.collect{ |tr| tr[1].text }
#=> ["1b", "2b"]
Run Code Online (Sandbox Code Playgroud)