[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 ...
随机推荐
- 大数据学习笔记——Hive完整部署流程
Hive详细部署教程 此篇博客承接上篇Hadoop和Zookeeper的部署教程,将会详细地对HIve的部署做一个整理,Hive相当于是封装在HDFS和Mapreduce上的一套sql引擎,只需要安装 ...
- 【Java Web开发学习】Spring环境profile
[Java Web开发学习]Spring 环境profile 转载:http://www.cnblogs.com/yangchongxing/p/8890702.html 开发.测试.生产环境往往是不 ...
- python故障排除
在初学 Python 时,想要弄懂 Python 的错误信息的含义可能有点复杂.这里列出了常见的的一些让程序 crash 的运行时错误. 1)忘记在 if , elif , else , for , ...
- C语言中表达n次方
C语言中表达n次方可以用pow函数. 函数原型:double pow(double x, double y) 功 能:计算x^y的值 返 回 值:计算结果 举例: double a; a = p ...
- 2016/11/10 kettle概述
ETL(Extract-Transform-Load,即抽取,转换,加载),数据仓库技术,是用来处理将数据从来源(以前做的项目)经过抽取,转换,加载到达目的端(正在做的项目)的过程.也就是新的项目需要 ...
- [译]C# 7系列,Part 6: Read-only structs 只读结构
原文:https://blogs.msdn.microsoft.com/mazhou/2017/11/21/c-7-series-part-6-read-only-structs/ 背景 在.NET世 ...
- 基于Vue的前后端分离项目实践
一.为什么需要前后端分离 1.1什么是前后端分离 前后端分离这个词刚在毕业(15年)那会就听说过,但是直到17年前都没有接触过前后端分离的项目.怎么理解前后端分离?直观的感觉就是前后端分开去做,即功 ...
- idea2019注册码,亲测可用!
2019已经过半了,最近可把我忙死了,好久没打理这里的留言了. 今天登上来,看到许多同学反馈按照之前的那篇文章 IntelliJ IDEA 2018激活码 永久破解 里的步骤无法破解idea,其实用这 ...
- mongodb 简单的增删改查
增加 语法: db.collectionName.insert({json对象}); 1. 增加单个文档,json对象格式 db.user.insert({name:'lee',age:23,sex: ...
- Paper | MFQE 2.0: A New Approach for Multi-frame Quality Enhancement on Compressed Video
目录 1. 要点 2. 压缩视频特性分析 2.1 质量波动 2.2 帧间相关性 3. 方法 3.1 分类器 3.2 好帧运动补偿 3.3 质量增强网络 4. 实验 4.1 差帧质量提升效果 4.2 总 ...