[python / selenium] - 用python刷公选课是一种什么体验?
前言
看公选课还是能学到很多知识的,这里是给大家提供一个selenium的使用思路(好好学公选课,我真的看了)
思路
当观看者移动鼠标到某一范围时就会停止播放,就让selenium一直将鼠标悬停在视频处;
视频中途会弹出问题,一旦弹出问题的元素出现,就播放音效提示用户去作答,作答完毕后继续让selenium接管(已实现自动作答,但仍存在小问题)
当每节观看时间任务达成后,自动点击下一视频进行播放。
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
from selenium.webdriver.common.action_chains import ActionChains
from playsound import playsound
from selenium.webdriver.support import expected_conditions as EC
import time
'''
使用前提:
使用前需要将google\chrome\application文件夹加入到环境变量中,同时下载相应的webdriver版本也将其放到application文件夹下面
然后在在cmd中键入chrome.exe --remote-debugging-port=9222 --user-data-dir="C:\selenum\AutomationProfile"
同时需要自行登陆进入视频学习界面(暂时没有研究出不靠selenium接管直接破验证码的方式)
存在的问题:
基本上视频中的弹框,选择第一个都能解决问题,在之后的测试中遇到答案错误情况极其少,所以弹框点击部分可能存在一定问题
'''
chrome_options = Options()
chrome_options.add_experimental_option("debuggerAddress", "127.0.0.1:9222")
# chrome_driver地址
chrome_driver = "C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe"
driver = webdriver.Chrome(chrome_driver, chrome_options=chrome_options)
time.sleep(2)
a = driver.find_elements_by_xpath("//div[@class='ncells']//a")
title = []
element = []
tt = []
# 获取的和标题的每节的名称存在空格的区别
for i in a:
title.append(i.get_attribute("title"))
tt.append(str.strip(i.get_attribute("title")))
def do():
t = driver.find_element_by_tag_name("h1").text
print("现在正在学习的是:", t)
driver.switch_to.frame('iframe')
iframe = driver.find_element_by_tag_name("iframe")
iframe.click()
oldtime = -1
i = 1
while True:
ActionChains(driver).move_to_element(iframe).perform()
driver.switch_to.frame(iframe)
# 有时候会自动暂停,如果在x秒内,进度没有变,就进行点击行为
if i == 1:
time.sleep(3)
i = 100
process = float(driver.find_element_by_xpath("//div[@role='slider']").get_attribute("aria-valuenow"))
print("现在已经播放了:", process)
if process == oldtime:
driver.switch_to.parent_frame()
time.sleep(3)
iframe.click()
print("已经恢复播放")
driver.switch_to.frame(iframe)
time.sleep(3)
else:
oldtime = process
if process > 90:
# 当视频播放完毕后,播放音效提示
# playsound("7371.mp3")
print("该节已经播放完毕")
driver.switch_to.parent_frame()
time.sleep(3)
driver.switch_to.parent_frame()
time.sleep(5)
newt = (tt.index(str.strip(t)))+1
newt = title[newt]
driver.find_element_by_xpath("//a[@title='"+newt+"']").click()
time.sleep(3)
try:
# 对于每一章的第一个视频因为有三个选项,所以首先需要点击第二个视频部分
driver.find_element_by_xpath("//span[@title='学习目标']")
driver.find_element_by_xpath("//span[@title='视频']").click()
except:
pass
print("现在来到了新视频:", driver.current_url)
t = str.strip(driver.find_element_by_tag_name("h1").text)
print("现在正在学习的是:", t)
time.sleep(2)
driver.switch_to.frame('iframe')
iframe = driver.find_element_by_tag_name("iframe")
iframe.click()
oldtime = -1
i = 1
continue
try:
# 视频中途弹出问题就播放音效提示去作答
driver.find_element_by_xpath("//input[@name='ans-videoquiz-opt']")
# playsound("12105.mp3")
print("----------答题时间到了----------")
# 选第一个基本上都是对的
driver.find_elements_by_xpath("//input[@type='radio']")[0].click()
time.sleep(2)
driver.find_element_by_xpath("//div[@class='ans-videoquiz-submit']").click()
try:
# 可能还是存在问题,没机会测试了
alt = driver.switch_to.alert()
alt.accept()
driver.switch_to.parent_frame()
print("----------点击弹框了!----------")
driver.find_elements_by_xpath("//input[@type='radio']")[1].click()
time.sleep(2)
driver.find_element_by_xpath("//div[@class='ans-videoquiz-submit']").click()
except:
pass
print('答题已经完成')
except:
pass
time.sleep(15)
driver.switch_to.parent_frame()
do()
效果展示

[python / selenium] - 用python刷公选课是一种什么体验?的更多相关文章
- python+selenium(python基础)
1.编辑器的选择 好刀不误砍柴工,那么我们写代码也需要一个利器,虽然python自带有python shell ,但我们在执行代码的时候,需要开很多窗口,最重要的一点是,代码文件的管理很不方便,笔者推 ...
- python网课自动刷课程序-------selenium+chromedriver
python的强大之处就在于有许多已经写好的功能库提供,这些库强大且易用,对于写一些有特定功能的小程序十分方便. 现在就用pyhton的selenium+谷歌游览器写一个可以自动刷课的程序,以智慧树上 ...
- 自动化选课(Python + selenium
前几天听到朋友说自己选课事情,突发奇想想要搞这样一个东西,但是由于各种原因只做到以下的完成度,具体的情况也会在解释的最后留下.这个只适用于曲师大的教务系统,因为用的这个系统来进行的一个调试,对于其 ...
- python+selenium 浏览器的问题
以前用selenium调用firefox是不需要驱动的,最近安装了python3.52+最新的firefox 发现调不起来了 搜索以后发现Firefox 47+需要搞个firefox的驱动 gecko ...
- Eclipse+Python+Selenium自动化测试框架搭建
1.下载Eclipse:http://www.eclipse.org/downloads/ 2.下载JDK:http://www.oracle.com/technetwork/java/javaee/ ...
- 一次完整的自动化登录测试-基于python+selenium进行cnblog的自动化登录测试
Web登录测试是很常见的测试!手动测试大家再熟悉不过了,那如何进行自动化登录测试呢!本文作者就用python+selenium结合unittest单元测试框架来进行一次简单但比较完整的cnblog自动 ...
- Python + Selenium 实现登录Office 365
最近捡起之前用的Python + Selenium实现工作中需要的登录Office 365功能.(吐槽:国内网络真是卡,登录Office 365实属不易.另外Selenium这样的网站都要墙,无法理解 ...
- python+selenium+Robot
准备工作: 1.下载python2.7 http://python.org/getit/ 2.下载下载setuptools [python 的基础包工具] 可以帮助我们轻松的下载,构建,安装,升级,卸 ...
- python+selenium运行报错UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128)
使用python+selenium运行自动化脚本时,打印某一段文字出现UnicodeEncodeError: 'ascii' codec can't encode characters in posi ...
随机推荐
- Jmeter查看结果树之查看响应的13种方法[详解]
查看结果树查看响应有哪几种方法,可通过左侧面板底部的下拉框选择 1.Text 查看结果树中请求的默认格式为text,会显示请求的取样器结果.请求.响应数据3个部分内容. 取样器结果: 默认Raw视图, ...
- CentOS7添加自定义脚本服务
一.CentOS7添加自定义脚本服务说明 在CentOS7下,已经不再使用chkconfig命令管理系统开机自启动服务和条件自定义脚本服务了,而是使用管理unit的方式来控制开机自启动服务和添加自定义 ...
- Python3之Django的Cookie与Session的使用
一.Cookie的使用 1.设置Cookie url.set_cookie("tile","zhanggen",expires=value,path='/' ) ...
- java开发必学知识:动态代理
目录 1. 引言 2. 代理模式及静态代理 2.1 代理模式说明 2.2 静态代理 2.3 静态代理局限性 3. 动态代理 3.1 JAVA反射机制 3.2 JDK动态代理 3.2.1 JDK动态代理 ...
- webpack学习_webpack-dev-server自动编译代码
之前每次修改完之后都要执行npm run build来编译,下面有三种方式可以实现代码变化后自动编译代码,下面只重点说webpack-dev-server,其他的请看webpack开发文档 1.web ...
- 常见面试题之*args 和 **kwargs 的使用
def self_max(*args,**kwargs): print(args) print(kwargs) self_max(1,2,3,4,5,6,7,x=6,y=8,z=80,e=50) 输出 ...
- 时间轮算法(TimingWheel)是如何实现的?
前言 我在2. SOFAJRaft源码分析-JRaft的定时任务调度器是怎么做的?这篇文章里已经讲解过时间轮算法在JRaft中是怎么应用的,但是我感觉我并没有讲解清楚这个东西,导致看了这篇文章依然和没 ...
- Tomcat系列(一)- 整体架构
整体架构 我们想要了解一个框架,首先要了解它是干什么的,Tomcat我们都知道,是用于处理连接过来的Socket请求的.那么Tomcat就会有两个功能: 对外处理连接,将收到的字节流转化为自己想要的R ...
- c++-内联函数和函数重载和默认参数和函数指针
内联函数 C++ 内联函数是通常与类一起使用.如果一个函数是内联的,那么在编译时,编译器会把该函数的代码副本放置在每个调用该函数的地方. 对内联函数进行任何修改,都需要重新编译函数的所有客户端,因为编 ...
- 数据卷(Data Volumes)
Docker宿主机和容器之间文件拷贝docker copy 前言: Docker 数据管理 在生产环境中使用 Docker ,往往需要对数据进行持久化,或者需要在多个容器之间进行 数据共享,这必然涉及 ...