Ruby でCyapybaraを使ってブラウザタイプのクローラーを作成しています。テールブルデータ(HTML)の特定の列のtdだけを最上段から最下段まで順番にクリックしてリンク先ページをsave_pageで保存したいと考えていますが、現在、全てのテーブルtdのリンクをクリックしてしまう状態です、クリック先を指定する方法はないでようか?
現状下記のようにプログラムしています。
-- coding utf-8 --
require 'capybara'
require 'capybara/dsl'
require 'selenium-webdriver'
require 'capybara/poltergeist'
Capybara.current_driver=:selenium
Capybara.app_host="http://www.example.com"
Capybara.default_max_wait_time=5
module Crawler
class Example
include Capybara::DSL
------ログイン後---------
def click_link
within(:xpath,'//*[@id="example"]')do
for i in 0..(all('A').length-1)
all('A')[i].click
save_page
go_back
end
crawler=Crawler::Example.new
crawler.login
crawler.click_link
対象のtdのXpathは下記のようになっています。
.//[@id='Example']/table/tbody/tr/td/table/tbody/tr[2]/td/table/tbody/tr[2]/td[1]/font/a
.//[@id='Example']/table/tbody/tr/td/table/tbody/tr[2]/td/table/tbody/tr[3]/td[1]/font/a
.
.
.
//td[1]/font/aに着目して、
within(:xpath,'//*[@id="example"]//td[1]/font/a')do
としてみましたが、うまくいきません。
何かよい方法はないでしょうか?
補足情報(言語/FW/ツール等のバージョンなど)
Ruby 2.2.4-p230
caypybara 2.7.0
poltergeist 1.9.0
selenium-webdriver 2.53.0
phantomjs-2.1.1-windows
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/04/25 00:58