2017-10-17 1 views
1

xmlダウンロードリンクを持つWebページ内のすべてのハイパーリンクを探し、ループ内でそれらをダウンロードします。 上記のハイパーリンクがクリックされたときに発生するフォームがあり、ダウンロードを続行するために入力する必要があります。私は、Webページでは、このXMLファイルに関連する要素の可視性に問題が直面しているんだけど、私は、次のエラーメッセージが表示さ :私はここにコードを添付しましたPython Selenium CSS Selector:要素が表示されない

"selenium.common.exceptions.ElementNotInteractableException: Message: Element is not visible"

、これを是正するための任意の提案は次のようになりますとても有難い。

import os 
import time 
from selenium import webdriver 
from selenium.webdriver.common.keys import Keys 
from selenium.webdriver.support.ui import WebDriverWait 
from selenium.webdriver.support import expected_conditions as EC 
from selenium.webdriver.common.by import By 

fp = webdriver.FirefoxProfile() 

fp.set_preference("browser.download.folderList", 2) 
fp.set_preference("browser.download.manager.showWhenStarting", False) 
fp.set_preference("browser.download.dir", "F:\Projects\Poli_Map\DatG_Py_Dat") 
fp.set_preference("browser.helperApps.neverAsk.saveToDisk", "text/xml") 

driver = webdriver.Firefox(firefox_profile=fp) 

m = 'xml' 
driver.get('https://data.gov.in/catalog/variety-wise-daily-market-prices-data-cauliflower') 
wait = WebDriverWait(driver, 10) 

elem = driver.find_element_by_xpath("//*[@href]") 
elem.send_keys("xml") 
elem.send_keys(Keys.RETURN) 

wait.until(EC.visibility_of_element_located((By.CSS_SELECTOR, ".list-recent-events li"))) 

assert m in driver.page_source 
for link in elem: 
    link.click() 


    class FormPage(object): 
     def fill_form(self, data): 
      driver.execute_script("document.getElementById('edit-download-reasons-non-commercial').click()") 
      driver.execute_script("document.getElementById('edit-reasons-d-rd').click()") 
      driver.find_element_by_xpath('//input[@name = "name_d"]').send_keys(data['name_d']) 
      driver.find_element_by_xpath('//input[@name = "mail_d"]').send_keys(data['mail_d']) 
      return self 

     def submit(self): 
      driver.execute_script("document.getElementById('edit-submit').click()") 


    data = { 
     'name_d': 'xyz', 
     'mail_d': '[email protected]', 
    } 

    time.sleep(3) 
    FormPage().fill_form(data).submit() 

答えて

0

すべてのハイパーリンクではなく、XMLのみを検索する必要があります。ロケータ//*[@href]はすべてのHREFリンクを探しています。以下のコードを使用してください

#locate all the links which have xml 
allelements = driver.find_elements_by_xpath("//a[text()='xml']") 

# Iterate all links one by one 
for element in allelements: 
    element.click() 
    class FormPage(object): 
     def fill_form(self, data): 
      driver.execute_script("document.getElementById('edit-download-reasons-non-commercial').click()") 
      driver.execute_script("document.getElementById('edit-reasons-d-rd').click()") 
      driver.find_element_by_xpath('//input[@name = "name_d"]').send_keys(data['name_d']) 
      driver.find_element_by_xpath('//input[@name = "mail_d"]').send_keys(data['mail_d']) 
      return self 

     def submit(self): 
      driver.execute_script("document.getElementById('edit-submit').click()") 


    data = { 
     'name_d': 'xyz', 
     'mail_d': '[email protected]', 
    } 
    time.sleep(5) 
    FormPage().fill_form(data).submit() 

    #It opens the download link in new tab So below code again switch back to parent window itself 
    window_before = driver.window_handles[0] 
    driver.switch_to_window(window_before) 
+0

NarendraRにお返事ありがとうございます。実行と1回目のダウンロード後、私は次のエラーに直面します: selenium.common.exceptions.StaleElementReferenceException:メッセージ: staleの要素参照:要素がもはやDOMまたはページがリフレッシュされました – Cashi

関連する問題