【发布时间】:2018-11-15 01:54:48
【问题描述】:
我正在尝试编写一个脚本,使用 selenium 下载许多包含不同 NHL 球员信息的文件;游戏日志。我想为下表中的每个玩家下载一个文件:https://www.naturalstattrick.com/playerteams.php?fromseason=20142015&thruseason=20162017&stype=2&sit=all&score=all&stdoi=std&rate=y&team=ALL&pos=S&loc=B&toi=0.1&gpfilt=none&fd=&td=&tgp=410&lines=single
在那个网站上,我想点击表格中所有玩家的名字。当通过 href 链接点击玩家的名字时,会打开一个新窗口。顶部有几个下拉菜单。我想选择“Rate”而不是“Counts”,还要选择“Game Log”而不是“Player Summary”,然后点击“Submit”。最后,我想点击底部的 CSV(All) 来下载一个 CSV 文件。
这是我当前的代码:
from selenium import webdriver
import csv
from selenium.webdriver.support.ui import Select
from datetime import date, timedelta
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
chromedriver =("C:/Users/Michel/Desktop/python/package/chromedriver_win32/chromedriver.exe")
driver = webdriver.Chrome(chromedriver)
driver.get("https://www.naturalstattrick.com/playerteams.php?fromseason=20142015&thruseason=20162017&stype=2&sit=all&score=all&stdoi=std&rate=y&team=ALL&pos=S&loc=B&toi=0.1&gpfilt=none&fd=&td=&tgp=410&lines=single")
table = driver.find_element_by_xpath("//table[@class='indreg dataTable no-footer DTFC_Cloned']")
for row in table.find_elements_by_xpath("//tr[@role='row']")
links = driver.find_element_by_xpath('//a[@href]')
links.click()
select = Select(driver.find_element_by_name('rate'))
select.select_by_value("y")
select1 = Select(driver.find_element_by_name('v'))
select1.select_by_value("g")
select2 = Select(driver.find_element_by_type('submit'))
select2.select_by_value("submit")
WebDriverWait(driver, 5).until(EC.presence_of_element_located((By.XPATH , '//div[@class="dt-button button-csv button-htm15"]')))
CSVall = driver.find_element_by_xpath('//div[@class="dt-button button-csv button-htm15"]')
CSVall.click()
driver.close()
我尝试更改不同的内容,但总是出错。哪里有问题 ?
此外,我认为我可能应该添加一行来等待网站加载,因为它需要几秒钟;在“driver.get”之后。我不知道在这种情况下结束等待的预期条件应该是什么。
谢谢
【问题讨论】:
标签: python selenium web-scraping webdriverwait