Python利用Selenium实现自动观看学习通视频

目录
  • 一、登录
  • 二、进行一个页面的视频观看
  • 三、所有视频的观看
  • 四、总代码
  • 其他

一、登录

以信号与系统课程为例,直接输入网址则出现登录界面:

由于学号登录需要验证码,因此选择电话登录:

直接在开发者工具中找到手机号输入框、密码输入框和登录按钮,并进行输入和点击:

import time

from selenium.webdriver import Chrome

web = Chrome()

web.get('https://mooc2-ans.chaoxing.com/mycourse/stu?courseid=203430340&clazzid=43992529&cpi=93003203&enc=9726840999ffc15f3f441bb5466882e6&t=1637651449831&pageHeader=1')

# 登录
phone = web.find_element_by_class_name('ipt-tel')
pwd = web.find_element_by_class_name('ipt-pwd')
login = web.find_element_by_class_name('btn-big-blue')

phone.send_keys('电话号码')
pwd.send_keys('密码')
login.click()
time.sleep(2)

二、进行一个页面的视频观看

登录成功后,如下:

找到所有的知识点页面:

all_no_list = web.find_elements_by_xpath('//span[@class="catalog_points_yi"]')

执行以上代码后,发现错误,通过开发者工具发现其在iframe中,因此需要先进入iframe:

# 进入iframe
frame_content = web.find_element_by_xpath('//*[@id="frame_content-zj"]')
web.switch_to.frame(frame_content)

time.sleep(2)

# 查找所有未完成的知识点页面
all_no_list = web.find_elements_by_xpath('//span[@class="catalog_points_yi"]')

紧接着进入第一个页面:

# 跳转到第一个知识点页面
all_no_list[0].click()
web.switch_to.window(web.window_handles[-1])  # 跳转到该知识点界面
time.sleep(5)

查找未完成的知识点的div(同样需要进入iframe):

iframe = web.find_element_by_id('iframe')  # 每次刷新后,都要进入内部iframe
web.switch_to.frame(iframe)
# 筛选,去除已完成的知识点
k_points = web.find_elements_by_css_selector('div.ans-attach-ct:not(.ans-job-finished)')

进入视频的播放:

num = len(k_points)
for i in range(0, num):
    k_point = k_points[i]
    # 查找任务图标个数,1为知识点,0为不是知识点
    icon_num = len(k_point.find_elements_by_xpath('./div[contains(@class,"ans-job-icon")]'))
    if icon_num == 0:  # 再次筛选,去除不是知识点的div
        continue
    # 进行视频的播放
    video_iframe = k_point.find_element_by_xpath('./iframe')  # 视频iframe
    print(video_iframe)
    time.sleep(2)
    web.switch_to.frame(video_iframe)  # 进入视频iframe
    time.sleep(2)
    web.find_element_by_class_name('vjs-big-play-button').click()  # 点击播放按钮
    time.sleep(1)
    web.find_element_by_xpath('//*[@id="video"]/div[5]/div[6]/button').click()  # 静音
    # 播放和暂停按钮
    pause_btn = web.find_element_by_xpath('//button[contains(@class,"vjs-play-control")and '
                                          'contains(@class,"vjs-control")and contains(@class,"vjs-button")]')
    while (1):  # 播放等待
        time.sleep(1)  # 每1秒,检查视频是否播放完毕
        if (pause_btn.get_attribute('title') == "重播"):  # 点击后播放,即播放完毕状态
            break
    print('视频播放完毕')
    # 视频播放完毕,退出播放iframe,然后退出循环,再次查找该页面的所有知识点(k_points)
    web.switch_to.default_content()
    print('退出知识点iframe')
    time.sleep(2)

经过测试后,发现播放完一个视频后,k_points(即知识点列表)发生改变,不能继续使用该列表中的元素,因此需要重新获取,则需要刷新页面。

观看一个视频方法如下:

# 完成一个页面的所有未完成的知识点
def view_one_page_points():
    while (1):
        iframe = web.find_element_by_id('iframe')  # 每次刷新后,都要进入内部iframe
        web.switch_to.frame(iframe)
        # 筛选,去除已完成的知识点
        k_points = web.find_elements_by_css_selector('div.ans-attach-ct:not(.ans-job-finished)')
        num = len(k_points)
        flag = False
        for i in range(0, num):
            if i == (num - 1):  # 是最后一个,表示该页刷完
                flag = True
            k_point = k_points[i]
            # 查找任务图标个数,1为知识点,0为不是知识点
            icon_num = len(k_point.find_elements_by_xpath('./div[contains(@class,"ans-job-icon")]'))
            if icon_num == 0:  # 再次筛选,去除不是知识点的div
                continue
            # 进行视频的播放
            video_iframe = k_point.find_element_by_xpath('./iframe')  # 视频iframe
            print(video_iframe)
            time.sleep(2)
            web.switch_to.frame(video_iframe)  # 进入视频iframe
            time.sleep(2)
            web.find_element_by_class_name('vjs-big-play-button').click()  # 点击播放按钮
            time.sleep(1)
            web.find_element_by_xpath('//*[@id="video"]/div[5]/div[6]/button').click()  # 静音
            # 播放和暂停按钮
            pause_btn = web.find_element_by_xpath('//button[contains(@class,"vjs-play-control")and '
                                                  'contains(@class,"vjs-control")and contains(@class,"vjs-button")]')
            while (1):  # 播放等待
                time.sleep(1)  # 每1秒,检查视频是否播放完毕
                if (pause_btn.get_attribute('title') == "重播"):  # 点击后播放,即播放完毕状态
                    break
            print('视频播放完毕')
            # 视频播放完毕,退出播放iframe,然后退出循环,再次查找该页面的所有知识点(k_points)
            web.switch_to.default_content()
            print('退出知识点iframe')
            time.sleep(2)
            web.refresh()  # 刷新页面,之后需重新进入iframe
            time.sleep(2)
            print('刷新页面')
            break
        if flag:  # 该页面知识点播放完毕
            break
    pass

三、所有视频的观看

之前在主页面获取了所有的知识点页面:

all_no_list = web.find_elements_by_xpath('//span[@class="catalog_points_yi"]')

和上一点的k_points需要重新获取类似,all_no_list每完成一个页面则也需要重新获取,因此代码如下:

while (1):
    # 进入iframe
    frame_content = web.find_element_by_xpath('//*[@id="frame_content-zj"]')
    web.switch_to.frame(frame_content)

    time.sleep(2)

    # 查找所有未完成的知识点页面
    all_no_list = web.find_elements_by_xpath('//span[@class="catalog_points_yi"]')
    list_num = len(all_no_list)  #知识点页面个数
    if list_num == 0:   # 没有知识点页面,即全部刷完
        break

    # 跳转到第一个知识点页面
    all_no_list[0].click()
    web.switch_to.window(web.window_handles[-1])  # 跳转到该知识点界面
    time.sleep(5)
    #####
    view_one_page_points()  # 播放该知识点页面的所有未完成的知识点视频
    #####
    print('完成一个知识点页面...')

    web.close()  # 关闭当前窗口
    # 该页面知识点完毕,关闭当前窗口,选择下一个知识点窗口
    web.switch_to.window(web.window_handles[0])  # 变更视角到该课程主界面
    time.sleep(1)
    # 刷新页面
    web.refresh()
    time.sleep(2)
    print('刷新主页面')
    pass

四、总代码

import time

from selenium.webdriver import Chrome

web = Chrome()

web.get('https://mooc2-ans.chaoxing.com/mycourse/stu?courseid=203430340&clazzid=43992529&cpi=93003203&enc=9726840999ffc15f3f441bb5466882e6&t=1637651449831&pageHeader=1')

# 1. 登录
phone = web.find_element_by_class_name('ipt-tel')
pwd = web.find_element_by_class_name('ipt-pwd')
login = web.find_element_by_class_name('btn-big-blue')

phone.send_keys('手机号码')
pwd.send_keys('密码')
login.click()
time.sleep(2)

# 完成一个页面的所有未完成的知识点
def view_one_page_points():
    while (1):
        iframe = web.find_element_by_id('iframe')  # 每次刷新后,都要进入内部iframe
        web.switch_to.frame(iframe)
        # 筛选,去除已完成的知识点
        k_points = web.find_elements_by_css_selector('div.ans-attach-ct:not(.ans-job-finished)')
        num = len(k_points)
        flag = False
        for i in range(0, num):
            if i == (num - 1):  # 是最后一个,表示该页刷完
                flag = True
            k_point = k_points[i]
            # 查找任务图标个数,1为知识点,0为不是知识点
            icon_num = len(k_point.find_elements_by_xpath('./div[contains(@class,"ans-job-icon")]'))
            if icon_num == 0:  # 再次筛选,去除不是知识点的div
                continue
            # 进行视频的播放
            video_iframe = k_point.find_element_by_xpath('./iframe')  # 视频iframe
            print(video_iframe)
            time.sleep(2)
            web.switch_to.frame(video_iframe)  # 进入视频iframe
            time.sleep(2)
            web.find_element_by_class_name('vjs-big-play-button').click()  # 点击播放按钮
            time.sleep(1)
            web.find_element_by_xpath('//*[@id="video"]/div[5]/div[6]/button').click()  # 静音
            # 播放和暂停按钮
            pause_btn = web.find_element_by_xpath('//button[contains(@class,"vjs-play-control")and '
                                                  'contains(@class,"vjs-control")and contains(@class,"vjs-button")]')
            while (1):  # 播放等待
                time.sleep(1)  # 每1秒,检查视频是否播放完毕
                if (pause_btn.get_attribute('title') == "重播"):  # 点击后播放,即播放完毕状态
                    break
            print('视频播放完毕')
            # 视频播放完毕,退出播放iframe,然后退出循环,再次查找该页面的所有知识点(k_points)
            web.switch_to.default_content()
            print('退出知识点iframe')
            time.sleep(2)
            web.refresh()  # 刷新页面,之后需重新进入iframe
            time.sleep(2)
            print('刷新页面')
            break
        if flag:  # 该页面知识点播放完毕
            break
    pass

while (1):
    # 进入iframe
    frame_content = web.find_element_by_xpath('//*[@id="frame_content-zj"]')
    web.switch_to.frame(frame_content)

    time.sleep(2)

    # 查找所有未完成的知识点页面
    all_no_list = web.find_elements_by_xpath('//span[@class="catalog_points_yi"]')
    list_num = len(all_no_list)  #知识点页面个数
    if list_num == 0:   # 没有知识点页面,即全部刷完
        break

    # 跳转到第一个知识点页面
    all_no_list[0].click()
    web.switch_to.window(web.window_handles[-1])  # 跳转到该知识点界面
    time.sleep(5)
    #####
    view_one_page_points()  # 播放该知识点页面的所有未完成的知识点视频
    #####
    print('完成一个知识点页面...')

    web.close()  # 关闭当前窗口
    # 该页面知识点完毕,关闭当前窗口,选择下一个知识点窗口
    web.switch_to.window(web.window_handles[0])  # 变更视角到该课程主界面
    time.sleep(1)
    # 刷新页面
    web.refresh()
    time.sleep(2)
    print('刷新主页面')
    pass

其他

bug:

如以下存在该div的页面,则无法读取其中视频。

 

到此这篇关于Python利用Selenium实现自动观看学习通视频的文章就介绍到这了,更多相关Python Selenium 自动观看视频内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python利用Selenium实现网站自动签到功能

    目录 什么是Selenium 前情提要 准备工作 代码及讲解 点击登录 点击跳过弹窗 小结 什么是Selenium 先带领大家学习下Selenium的基本概念吧. Selenium主要用于web应用程序的自动化测试,但并不局限于此,它还支持所有基于web的管理任务自动化. 它的特点如下: 开源,免费 多浏览器支持:Firefox.Chrome.IE等 多平台支持:Linux.Windows.Mac 多语言支持:Java.Python.Ruby.C#.JavaScript.C++ 对web页面有良

  • Python编程使用Selenium模拟淘宝登录实现过程

    目录 一.利用xpath进行(全程使用) 二.代码部分与图片内容 一.利用xpath进行(全程使用) driver.find_element_by_xpath() 二.代码部分与图片内容 打开淘宝网站,点击登录,输入账号密码,进入网站,搜索框中输入电脑,然后点击搜索 #导入selenium from selenium import webdriver #导入等待时间 import time #使用火狐浏览器进行访问 driver = webdriver.Firefox() #访问淘宝网站 dri

  • python自动化测试selenium屏幕截图示例

    WebDriver内置了测试中捕获屏幕并保存的方法. 示例脚本: (1)save_screenshot(filename):保存屏幕截图 from selenium import webdriver from time import sleep,strftime,localtime,time import os class TestScreenShot(object): def setup(self): self.driver = webdriver.Chrome() self.driver.g

  • Python+selenium 自动化快手短视频发布的实现过程

    第一章:效果展示 ① 效果展示 ② 素材展示 一个为视频,另一个为像素大小不小于视频的封面. 第二章:实现过程 ① 调用已启用的浏览器 通过调用已启用的浏览器,可以实现直接跳过每次的登录过程. from selenium import webdriver options = webdriver.ChromeOptions() options.add_experimental_option("debuggerAddress", "127.0.0.1:5003") dr

  • Python利用Selenium实现自动观看学习通视频

    目录 一.登录 二.进行一个页面的视频观看 三.所有视频的观看 四.总代码 其他 一.登录 以信号与系统课程为例,直接输入网址则出现登录界面: 由于学号登录需要验证码,因此选择电话登录: 直接在开发者工具中找到手机号输入框.密码输入框和登录按钮,并进行输入和点击: import time from selenium.webdriver import Chrome web = Chrome() web.get('https://mooc2-ans.chaoxing.com/mycourse/stu

  • python爬虫利用selenium实现自动翻页爬取某鱼数据的思路详解

    基本思路: 首先用开发者工具找到需要提取数据的标签列 利用xpath定位需要提取数据的列表 然后再逐个提取相应的数据: 保存数据到csv: 利用开发者工具找到下一页按钮所在标签: 利用xpath提取此标签对象并返回: 调用点击事件,并循环上述过程: 最终效果图: 代码: from selenium import webdriver import time import re class Douyu(object): def __init__(self): # 开始时的url self.start

  • python爬虫之利用selenium模块自动登录CSDN

    一.页面分析 CSDN登录页面如下图 二.引入selenium模块及驱动 2.1 并将安装好的Chromedriver.exe引入到代码中 # -*- coding:utf-8 -*- from selenium import webdriver import os import time #引入chromedriver.exe chromedriver="C:/Users/lex/AppData/Local/Google/Chrome/Application/chromedriver.exe&

  • python 利用toapi库自动生成api

    在学习做接口测试自动化的时候,我们往往会自己动手写一些简单的API,比如写一个简单的TODO API之类. 不过自己写API的时候经常需要造一些假数据,以及处理分页逻辑,开始的时候还觉得比较有意思,但久而久之就显得比较乏味了. 这时候你可能会想,有没有什么工具可以自动将一个线上的网站转化成简单的API呢? 这样的工具确实是存在的,而且不少,其中python语言中比较受欢迎的实现是https://github.com/gaojiuli/toapi项目,项目名称是toapi. 我们来简单体验一下这个

  • python利用selenium进行浏览器爬虫

    前言 相信大家刚开始在做爬虫的时候,是不是requests和sound这两个库来使用,这样确实有助于我们学习爬虫的知识点,下面来介绍一个算事较复杂的爬虫案例selenium进形打开浏览器爬取网站的信息 导入第三方库 自执行函数 解析信息 保存文件信息 打开浏览器 获取链接信息 执行函数 运行结果 总结 以上所述是小编给大家介绍的python利用selenium进行浏览器爬虫,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的.在此也非常感谢大家对我们网站的支持! 如果你觉得本

  • Python利用Selenium实现弹出框的处理

    目录 JavaScript三种弹出对话框的简单介绍 alert() - 警告框 confirm() - 确认框 cprompt() - 提示框 selenium 处理弹出对话框的常用方法 selenium 处理 alert() 弹窗 selenium 处理 confirm() 弹窗 selenium 处理 prompt() 弹窗 现如今经常出现在网页上的基于 JavaScript 实现的弹出框有三种,分别是 alert.confirm.prompt .该章节主要是学习如何利用 selenium

  • Python利用selenium建立代理ip池访问网站的全过程

    目录 一.使用selenium前? 1.安装selenium 2.安装浏览器驱动 3.配置环境 二.使用selenium 1.引入库 2.完整代码 总结 一.使用selenium前? 1.安装selenium pip install Selenium 2.安装浏览器驱动 Chrome驱动文件下载:点击下载 3.配置环境 1.将下载文件放进C:\Program Files (x86)\Google\Chrome\Application下就可以 2.然后配置下系统变量:我的电脑–>属性–>系统设置

  • Python利用PyAutoGUI实现自动点赞

    目录 前言 思路 实现 总结 前言 在上篇文章<Python自动操作 GUI 神器——PyAutoGUI>中,我跟大家讲解了一下 pyautogui 的一些基础知识和操作,大家反馈很好,给了我好多赞,在此先跟大家说声三克油! 在得到大家正反馈的同时,我受到了很大鼓舞,感觉如果只是介绍一下基础操作,有点不过瘾,所以今天晚上加班回来,虽然很不想打开电脑,但是还是忍着疲惫给大家奉献一个小实例. 为此,我跑去洗手间用凉水洗了一把脸,顿时清醒多了,下面进入正题. 作为一个 GUI 操作的神器,我们看到了

  • Python利用pywin32实现自动操作电脑

    目录 1. 简介 2. 示例代码 3. 效果图 4. 代码解释 5. 常见问题 1. 简介 在windows系统上,重复性的操作可以用Python脚本来完成,其中常用的模块是win32gui.win32con.win32api,要使用这三个模块需要先安装pywin32.在cmd中输入如下命令,即可安装pywin32: pip install pywin32 这三个模块作用如下: win32gui:模块定义了Windows下关于图形操作的API,如查找窗口句柄的函数FindWindow和FindW

随机推荐