2014-09-21 36 views
0

我有写这个程序来自动执行我在工作中的任务。这是我第一次尝试编程,没有任何经验或训练,因此可以原谅任何愚蠢的错误。 (我删除的网站和我的用户名/密码)Ruby:如果满足结束标准,则重新运行使用不同代码的循环

require "rubygems" 
require "selenium-webdriver" 
require "nokogiri" 
browser = Selenium::WebDriver.for :firefox 
wait = Selenium::WebDriver::Wait.new(:timeout => 15) 
#loads to unassigned results page 
browser.get "-----------------" 
p browser.title 
browser.find_element(name: "user[username]").send_keys "--------" 
browser.find_element(name: "user[password]").send_keys "--------" 
browser.find_element(name: "commit").click 
p browser.title 
browser.find_element(class_name: "status_notification").click 
begin 
    browser.find_element(:xpath => ".//*[@id='sub_nav_content']/table/tbody/tr[2]/td[3]/a").click 
    table = wait.until { 
     element = browser.find_element(id: "possible_matched") 
     element if element.displayed? 
    } 
    if table 
     puts "Table Found" 
    else 
     puts "Table Error" 
    end 
    #creates an 2D array containing patient name, admit date and prints to screen 
    names = browser.find_elements(:xpath => ".//*[@id='possible_matched']/table/tbody/tr/td[1]") 
    name_array = [] 
    names.each { |name| name_array << name.text} 
    admits = browser.find_elements(:xpath => ".//*[@id='possible_matched']/table/tbody/tr/td[5]") 
    admit_array = [] 
    admits.each { |date| admit_array << date.text } 
    name_admit_array = name_array.zip(admit_array) 
    name_admit_array.each do |name, date| 
     puts "#{name}: #{date}" 
    end 
    #finds the location of the sub-array containing patient name and collection associated admit date 
    patient_name = browser.find_element(:xpath => ".//*[@id='dialog-modal-cancel-hl7-preview']/table/tbody/tr[2]/td[1]").text 
    collected_date = browser.find_element(:xpath => ".//*[@id='dialog-modal-cancel-hl7-preview']/table/tbody/tr[2]/td[4]").text 
    mo, da, yr = collected_date.split('/').map(&:to_i) 
    cd = [yr, mo, da] 
    bl = name_admit_array.each_with_index.select { |(name, date), i| 
     m, d, y = date.split('/').map(&:to_i) 
     dt = [y, m, d] 
     name.downcase == patient_name.downcase and (dt <=> cd)<0 
    }.map {|x, i| i } 
    # presses the button associated with the correct sub-array 
    blf = name_admit_array.values_at(*bl) 
    if bl.any? 
     bf = blf.rindex(blf.max) + 2 
     browser.find_element(:xpath => ".//*[@id='possible_matched']/table/tbody/tr[#{bf}]/td[6]/div/a").click 
    else 
     browser.find_element(:xpath => "html/body/div[6]/div[1]/a/span").click 
    end 
end while bl.any? 
puts "no name :(" 

所以它运行的循环,直到没有什么数组bl中发现的。我想要做的是让这个循环再次运行,但链接列表中的下一个链接。所以在循环开始时,它应该执行browser.find_element(:xpath => ".//*[@id='sub_nav_content']/table/tbody/tr[3]/td[3]/a").click而不是browser.find_element(:xpath => ".//*[@id='sub_nav_content']/table/tbody/tr[2]/td[3]/a").click。然后应该以相同的方式运行循环的其余部分。我希望它在每次循环运行到br.any? => false时继续增加tr[]

回答

0

您可以创建xpath秒的阵列,并为他们的each运行这段代码:

[ 
    ".//*[@id='sub_nav_content']/table/tbody/tr[3]/td[3]/a", 
    ".//*[@id='sub_nav_content']/table/tbody/tr[2]/td[3]/a" 
].each do |path| 
    begin 
     browser.find_element(:xpath => path).click 
     // etc.... 

    end while bl.any? 
end 

我相信会有更多的变化需要调整你的代码可重用,可根据您的需要

+0

这似乎喜欢它应该工作,但是当我像这样运行它会得到第二个条目,并给我:元素不再连接到DOM :( – 2014-09-22 15:12:31

相关问题