この質問への回答で li 要素の配列で div 要素にアクセスし、 ここを見るとhttp://wiki.openqa.org/display/WTR/Collections+of+HTML+Elements
何をする必要があるのかわからない、または理解できない
私がやろうとしているのは、ギルドのplayer_name、player_id、およびplayer_lvlを使用してスプレッドシートを作成することです.
ギルドメンバーのページです。 ギルドページ 彼女はHTMLのサンプルです
<div class="guild_board">
<div class="item_box_guild" data-playerid="1256824509">
<a onclick="doCmd(81,{'player_id':'1256824509'})"><div class="tile_50">
<div class="avatar_container_50">
<div class="avatar_image" style="background-image:url(//assets.ageofchampions.com/avatar/09/45/82/56/12/avatar_1351896996145.png);">
</div>
</div>
<div class="over">
<img src="http://profile.ak.fbcdn.net/hprofile-ak-ash4/187582_1256824509_1172546357_q.jpg">
</div>
<div class="lock"></div>
</div>
</a>
<div class="content">
<div class="stat" style="width:225px;">
<a onclick="doCmd(81,{'player_id':'1256824509'})">~|SR|~ Kariselle</a> |
Level 348 <hr>
Battle Score: 23,951,169
このコードは最初のメンバーを取得するために機能し、次のメンバーなどを取得するために (=>index (2)) を実行できます。現時点でメンバーは10人ですが、もっと大きくなる可能性があります。必要がない場合は、メンバーごとにこれを書く必要はありません。
require 'rubygems'
require 'watir-webdriver'
require 'google_drive'
b = Watir::Browser.new
b.goto 'http://game.ageofchampions.com/aoc/?cmd%5B0%5D=112&guild_id=138668'
b.text_field(:id => 'email').set 'email'
b.text_field(:id => 'pass').set 'psswd'
b.button(:name => 'login').click
session = GoogleDrive.login('username', 'pass')
ws=session.spreadsheet_by_key('spreadsheethe').worksheets[0]
b.goto 'game.ageofchampions.com/aoc/?cmd%5B0%5D=112&guild_id=138668'
#b.divs(:class => 'item_box_guild').each do |div|
playerid_1 = b.div(:class => 'item_box_guild').attribute_value(:'data-playerid')
#playerid_1a = puts attribute_value(:'data-playerid')
#end
playername_1 = b.div(:class => 'item_box_guild').div(:class => 'stat').a.text
#playerlvl_1 = b.div(:class => 'item_box_guild').div(:class => 'stat').text
#layerlvl_1a = playerlvl_1\s+id="0"\s+value="(.+?)"
# Gets content of A2 cell.
p ws[2, 1] #==> "hoge"
# Changes content of cells.
# Changes are not sent to the server until you call ws.save().
ws[1, 1] = "PLAYER ID"
ws[1, 2] = "CHAMPIONS NAME"
ws[1, 3] = "LEVEL"
ws[2, 1] = playerid_1
ws[2, 2] = playername_1
ws[2, 3] = "still working on lvl"
ws[3, 1] = "does this"
ws[3, 2] = "still"
ws[3, 3] = "work"
ws.save()
# Dumps all cells.
for row in 1..ws.num_rows
for col in 1..ws.num_cols
p ws[row, col]
end
end
# Yet another way to do so.
#p ws.rows #==> [["fuga", ""], ["foo", "bar]]
# Reloads the worksheet to get changes by other clients.
ws.reload()