以上のURLを参考にマルチスレッドによるタイムアウト処理をしようとしています。問い合わせた結果が返ってこない事があります。
Webdriverを代入した変数driverを関数の引数で渡そうとすると
TypeError: scraipNico() argument after * must be an iterable, not WebDriver
というエラーが出ます。
一つ目のコードブロックは参考URLのコードの一部を丸々コピーしています。
回答よろしくお願いいたします。
from time import sleep #この方法でimportすると、sleep以外のtime内の関数にアクセスできなくなるので注意してください。 import time from selenium import webdriver from selenium.common.exceptions import NoSuchElementException import datetime import threading class RunWithTimeout(object): def __init__(self, function, args): self.function = function self.args = args self.answer = None def worker(self): self.answer = self.function(*self.args) def run(self, timeout): thread = threading.Thread(target=self.worker) thread.start() thread.join(timeout) return self.answer
def scraipNico(driver): return(driver.find_elements_by_class_name("nicolib-SuggestSearch-suggestion-item-name")) def test(arrays): driver = webdriver.Chrome("D:\Usr\******\Downloads\chromedriver_win32\chromedriver.exe") driver.get("http://www.nicovideo.jp/video_top") #driver.get("D:\Usr\******\myDwk\DB_Mydynam\nicotest\abc.html") resultArray = [] sleep(1) driver.implicitly_wait(30) driver.get_screenshot_as_file("./Screenshots/NicoNico.png") sleep(1) for i in range(len(arrays)): try: aaa = driver.find_element_by_name("s") aaa.clear() aaa.send_keys(arrays[i]) bbb = driver.find_element_by_name("header_search") #bbb.submit() #サジェストが表示されない文字があるので #マルチスレッドしてタイムアウト処理 sleep(1)#スレッド乱立防止スリープ n = RunWithTimeout(scraipNico, driver) cccs = n.run(3)#処理を3秒まで待つ print (cccs)#デバッグ if cccs is None: continue #None hoge = []#日付の取得 hoge.append(datetime.now().strftime("%Y%m%d")) hoge.append(arrays[i]) for c in cccs: hoge.append(c.text) print(hoge) resultArray.append(hoge) except NoSuchElementException as e: print("要素がありませんでした...") else: print("要素はあります。") finally: piyo=10 #driver.quit() return(resultArray)
aaa = [chr(i) for i in range(97, 97+26)]#アルファベット test(aaa)
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/05/12 03:13