Ruby 显示 table 元素详细信息的代码
Ruby code to display table element details
我有一个 HTML 以下列方式显示产品详细信息:
<div class="column">
<h3 class="hidden-xs">Product Details</h3>
<table class="table table-striped">
<tbody>
<tr class="header-row hidden-xs">
<th>Product</th>
<th>Duration</th>
<th>Unit Price</th>
<th>Price</th>
</tr>
<tr>
<td>google.com</td>
<td>1 Year</td>
<td class="hidden-xs"></td>
<td></td>
</tr>
</tbody>
</table>
<div class="totals text-right">
<p>Subtotal: </p>
<p>Total: </p>
</div>
</div>
Ruby代码如下:
require 'watir'
browser = Watir::Browser.new(:chrome)
browser.goto('file:///C:/Users/Ashwin/Desktop/text.html')
browser.table(:class, 'table table-striped').trs.each do |tr|
p tr[0].text
p tr[1].text
p tr[2].text
p tr[3].text
end
我这样得到输出:
"Product"
"Duration"
"Unit Price"
"Price"
"google.com"
"1 Year"
""
""
但我希望详细信息显示如下:
Product : google.com
Duration : 1 Year
Unit Price :
Price :
有人可以帮忙吗?
此代码仅适用于给定的 table 两行
require 'watir'
browser = Watir::Browser.new(:chrome)
browser.goto('file:///C:/Users/Ashwin/Desktop/text.html')
browser.table(:class, 'table table-striped').rows.each_with_index do |row,index|
if index.eql?0
firstRow=row
next
end
p firstRow[0].text+":"+row[0].text
p firstRow[1].text+":"+row[1].text
p firstRow[2].text+":"+row[2].text
p firstRow[3].text+":"+row[3].text
end
table看起来很简单,所以可以使用Table#strings
方法将table转换成字符串数组。然后你可以输出每一列 header 每行值。
# Get the table you want to work with
table = browser.table(class: 'table table-striped')
# Get the text of the table
rows = table.strings
# Get the column headers and determine the longest one
header = rows.shift
column_width = header.max { |a, b| a.length <=> b.length }.length
# Loop through the data rows and output the header/value
rows.each do |row|
header.zip(row) do |header, value|
puts "#{header.ljust(column_width)} : #{value}"
end
end
#=> Product : google.com
#=> Duration : 1 Year
#=> Unit Price :
#=> Price :
我有一个 HTML 以下列方式显示产品详细信息:
<div class="column">
<h3 class="hidden-xs">Product Details</h3>
<table class="table table-striped">
<tbody>
<tr class="header-row hidden-xs">
<th>Product</th>
<th>Duration</th>
<th>Unit Price</th>
<th>Price</th>
</tr>
<tr>
<td>google.com</td>
<td>1 Year</td>
<td class="hidden-xs"></td>
<td></td>
</tr>
</tbody>
</table>
<div class="totals text-right">
<p>Subtotal: </p>
<p>Total: </p>
</div>
</div>
Ruby代码如下:
require 'watir'
browser = Watir::Browser.new(:chrome)
browser.goto('file:///C:/Users/Ashwin/Desktop/text.html')
browser.table(:class, 'table table-striped').trs.each do |tr|
p tr[0].text
p tr[1].text
p tr[2].text
p tr[3].text
end
我这样得到输出:
"Product"
"Duration"
"Unit Price"
"Price"
"google.com"
"1 Year"
""
""
但我希望详细信息显示如下:
Product : google.com
Duration : 1 Year
Unit Price :
Price :
有人可以帮忙吗?
此代码仅适用于给定的 table 两行
require 'watir'
browser = Watir::Browser.new(:chrome)
browser.goto('file:///C:/Users/Ashwin/Desktop/text.html')
browser.table(:class, 'table table-striped').rows.each_with_index do |row,index|
if index.eql?0
firstRow=row
next
end
p firstRow[0].text+":"+row[0].text
p firstRow[1].text+":"+row[1].text
p firstRow[2].text+":"+row[2].text
p firstRow[3].text+":"+row[3].text
end
table看起来很简单,所以可以使用Table#strings
方法将table转换成字符串数组。然后你可以输出每一列 header 每行值。
# Get the table you want to work with
table = browser.table(class: 'table table-striped')
# Get the text of the table
rows = table.strings
# Get the column headers and determine the longest one
header = rows.shift
column_width = header.max { |a, b| a.length <=> b.length }.length
# Loop through the data rows and output the header/value
rows.each do |row|
header.zip(row) do |header, value|
puts "#{header.ljust(column_width)} : #{value}"
end
end
#=> Product : google.com
#=> Duration : 1 Year
#=> Unit Price :
#=> Price :