Следующий код должен работать благодаря предложению, сделанному из OP1 . Чтобы получить currentTime видео HTML с использованием JS, можно рассмотреть следующее:
Код JS для извлечения текущего видео:
"return document.getElementsByTagName('video')[0].currentTime;"
. выше JS может быть выполнено с использованием метода execute_script
time_video = browser.execute_script("return document.getElementsByTagName('video')[0].currentTime;")
Чтобы исследовать, способна ли вышеуказанная реализация получить синхронизацию видео, скажем, в середине видео. Сначала мы переходим к позиции , скажем, 180 se c из начальной точки, используя код ниже.
player_status = browser.execute_script("document.getElementsByTagName('video')[0].currentTime += 180;")
Полный код приведен ниже;
from selenium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions as EC
import time
chrome_options = webdriver.ChromeOptions()
browser = webdriver.Chrome(executable_path = r"some_path\Browsers\chromedriver.exe",
options = chrome_options)
browser.get("https://www.youtube.com/watch?v=nXbfZL5kttM")
WebDriverWait(browser, 70).until(EC.element_to_be_clickable(
(By.XPATH, "//button[@aria-label='Play']"))).click()
print('Fast forward')
player_status = browser.execute_script("document.getElementsByTagName('video')[0].currentTime += 80;")
print('Get Current time')
time_video = browser.execute_script("return document.getElementsByTagName('video')[0].currentTime;")