学习python有一段时间了,一直没有一个完整的项目。这次总算完成了一个小的项目-自动打开网页答题,虽然还不是很完美,也足够用了。

分享下过程。

首先理清思路:解析网页-->提取题目-->判断是否存在题库中-->答题

1、解析网页,我想到了爬虫中使用的request模块,但是考虑到后边的需要点击进行答题,最后在网上找到了更好用的selenium模块。然后进行selenium的相关配置(配置过程有许多坑,最为关键的就是浏览器对应的版本和webdriver存放位置),学习selenium的相关用法,为了更好的定位网页中的对象安装了selenium IDE插件。经过半天努力,终于能通过Firefox打开网页了。

2、通过selenium IDE插件确定要提取对象的位置,这个可以直接在浏览器的扩展程序中直接查找添加,添加好了记得重启浏览器。在定位对象过程中使用了id,class,css和xpath方法。搜索到以后使用get_attribute得到要操作页面的地址。

3、使用文本处理split方法对地址进行解析,提出题目中的题号,然后在已经知道答案的题库中搜索,如果有,返回答案,如果没有全部选择a。(由于不限制挑战次数,但是每天最多挑战成功3次。所以只答最高分值的题,其他都打错)

4、根据答案选择按钮,然后点击下一个,最后提交。然后再进行下一题,直到挑战成功三次。

在答题过程中还出现了限时答题的情况,需要判断是否存在和跳过,又进行进一步完善。

通过这次完整的小项目,有点小总结,就是网上有许多前人走过的路,总结好的经验,学习就是了,不过要懂得区分好与坏。先找到最核心的问题,简化为一个小的问题,然后在网上查找最简单精准的答案。先解决了,然后再确定一个问题进行解决,就这样逐步进行完善。

脚本如下:

'''

作者:Yeahlv

时间:2019-4-13

版本:v1.0

开发环境:Pycharm

'''

from selenium import webdriver

from selenium.webdriver.support.ui import WebDriverWait

import numpy as np

import time

题目的序号

timu_id_ar = [7,12,13,14,16,39,40]

题目的答案

timu_daan_ar=np.array([[3,4,4,4,4,3,4,4,4,1],[4,1,2,2,3,2,4,3,2,3],[2,1,2,3,4,4,4,3,2,2],[4,1,2,3,2,4,4,3,4,2],[1,2,2,3,4,3,2,1,2,3],[1,4,3,2,2,2,2,4,2,2],[4,1,2,2,2,2,3,4,2,2],[1,1,1,1,1,1,1,1,1,1]])

def wait_response_time(chrome,waittime,func):

# 返回 func执行结果

return WebDriverWait(chrome,waittime).until(func)

def automatic_login(name,pwd,url):

#chrome = webdriver.Firefox()

chrome.get(url)

time.sleep(2)

name_label = chrome.find_element_by_name("LoginForm[loginName]")

name_label.send_keys(name)

pwd_label = chrome.find_element_by_name("LoginForm[password]")

pwd_label.send_keys(pwd)

time.sleep(1)

login_label = chrome.find_element_by_class_name('login-submit')

login_label.click()

time.sleep(2)

chrome.get('https://www.qqyuedu.com/student-home/challenge/index')

获取题目地址

def huoqu_timu(url):

chrome.get(url)

is_ks = isElementExist_lt("开始挑战")

if is_ks:

challenge_label = chrome.find_element_by_link_text("开始挑战")

dizhi=challenge_label.get_attribute("href")

print('挑战题目的地址是:',dizhi)

return dizhi

else:

return False

def isElementExist_lt(link_text):

try:

chrome.find_element_by_link_text(link_text)

return True

except:

return False

def isElementExist_class(class_name):

try:

chrome.find_element_by_class_name(class_name)

return True

except:

return False

def isElementExist_path(path_name):

try:

chrome.find_element_by_xpath(path_name)

return True

except:

return False

def daan_trsf(num):

if num==1:

return "A"

if num==2:

return "B"

if num==3:

return "C"

if num==4:

return "D"

if num==5:

return "E"

else:

return "答案是不是输入错误?"

答题

def tiaozhan(url):

chrome.get(url)

# 取得题目索引

def timu_index(url):

num1 = int(url.split("=")[1].split("&")[0])

if num1 in timu_id_ar:

timu_index = timu_id_ar.index(num1)

else:

timu_index = 7

print("这道题不在题库内,答案全部选择A。")

return timu_index

#开始挑战

is_ks = isElementExist_lt("开始")

if is_ks:

challenge_label = chrome.find_element_by_link_text("开始")

challenge_label.click()

time.sleep(1)

#开始挑战

is_ks = isElementExist_lt("开始挑战")

if is_ks:

challenge_label = chrome.find_element_by_link_text("开始挑战")

challenge_label.click()

time.sleep(1)

x = timu_index(url)

print("题目序号是"+str(x), "题目答案是",timu_daan_ar[x])

for i in range(10):

is_ks = isElementExist_lt("开始")

if is_ks:

challenge_label = chrome.find_element_by_link_text("开始")

challenge_label.click()

time.sleep(1)

# 点跳过

is_tg = isElementExist_lt("跳过")

if is_tg:

challenge_label = chrome.find_element_by_link_text("跳过")

challenge_label.click()

time.sleep(1)

# 点击答案,模式css=.question-option-list-item:nth-child(1) input

#x=timu_index(url)

timu_daan_txt = ".question-option-list-item:nth-child("+str(timu_daan_ar[x][i])+") input"

print("第"+str(i+1)+"题选择:",daan_trsf(timu_daan_ar[x][i]))

challenge_label = chrome.find_element_by_css_selector(timu_daan_txt)

challenge_label.click()

time.sleep(1)

# 点击提交答案 xpath=//button[contains(.,'提交答案')]

is_tjda = isElementExist_path("//button[contains(.,'提交答案')]")

if is_tjda:

challenge_label = chrome.find_element_by_xpath("//button[contains(.,'提交答案')]")

challenge_label.click()

time.sleep(1)

break

is_xyt = isElementExist_class("ion-chevron-right")

if is_xyt:

challenge_label = chrome.find_element_by_class_name("ion-chevron-right")

challenge_label.click()

time.sleep(1)

is_tjda = isElementExist_class("btn btn-primary btn-lg")

if name == "main":

chrome = webdriver.Firefox()

name = "lvjianyi20090601"

pwd = "123456"

url = "https://www.qqyuedu.com/"

automatic_login(name,pwd,url)

#https://www.qqyuedu.com/challenge/default/quiz?challengeId=9&quizId=68&layoutMode=iframe

lyt = 0

while 1>0:

url_1=huoqu_timu('https://www.qqyuedu.com/student-home/challenge/index')

if url==False:

break

else:

tiaozhan(url_1)

lyt += 1

print("第"+str(lyt)+"次挑战")

python 根据答案 自动答题器_python根据题库答案自动答题相关推荐

  1. python选择题库和答案_python根据题库答案自动答题

    学习python有一段时间了,一直没有一个完整的项目.这次总算完成了一个小的项目-自动打开网页答题,虽然还不是很完美,也足够用了. 分享下过程. 首先理清思路:解析网页-->提取题目--> ...

  2. 完整答题小程序带流量主激励广告强点源码(答题小程序模板+题库)

    源码简介: ​答题小程序带流量主激励广告强点源码(答题小程序模板+题库),完整答题小程序源码有题库,无加密,带激励广告强制点击可提升广告收益.​ 下载链接 网盘源码   密码:3lev 背景 完整答题 ...

  3. 专技天下河北省2016年专业技术人员继续教育公需科目题库答案(答题器)

    专技天下河北省2016年专业技术人员继续教育公需科目题库答案(答题器) 科目包括河北省专业技术人员公需科目继续教育的必修的三门<当代科学技术新知识读本(一)>.<专业技术人员知识创造 ...

  4. 网页自动获取题目匹配题库答案填充(原创1.0)

    /***欢迎使用网页自动获取题目匹配题库答案填充(原创1.0)**1.可手动添加本地题库,一键复制,无序key自动匹配,2.通过调试可获取相应div类下的值/元素3.遍历实现多选,可在console中 ...

  5. python每隔一段时间保存网页内容_利用Python轻松爬取网页题库答案!教孩子不怕尴尬了!...

    大家有没有遇到这种令人尴尬的情况:"好不容易在网上找到需要的资源数据,可是不容易下载下来!"如果是通过一页一页的粘贴复制来下载,真的让人难以忍受,特别是像我这种急性子,真得会让人窒 ...

  6. 五分钟没有操作自动退出_智阅云自动阅读器app下载-智阅云自动阅读器app安卓版下载v1.0...

    智阅云自动阅读器是一款可以阅读赚钱的软件,这里有很多的文章,每天也都会有更新,在这里阅读文章赚钱还是比较靠谱的,大家可以放心. 智阅云自动阅读器app介绍 智阅云自动阅读器这里赚钱是比较简单的,还可以 ...

  7. Python网络爬虫与信息提取(17)—— 题库爬取与整理+下载答案

    前言 上一节实现了题目的整理,没整理答案是不完整的,所以这一节加上答案的爬取. 上一节地址:Python网络爬虫与信息提取(16)-- 题库爬取与整理 效果 思路 爬答案有点难搞,像这种题库的答案都是 ...

  8. python爬取学校题库_利用Python轻松爬取网页题库答案!教孩子不怕尴尬了!

    大家有没有遇到这种令人尴尬的情况:"好不容易在网上找到需要的资源数据,可是不容易下载下来!"如果是通过一页一页的粘贴复制来下载,真的让人难以忍受,特别是像我这种急性子,真得会让人窒 ...

  9. 条令考试小程序辅助器_可以自己编题的答题软件,自定义题库考试出题工具,微信答题小程序...

    自制题库自己编题的答题小程序要如何制作?今天给大家介绍下可以自己编题的答题软件,自制题库软件在微信小程序里自己出题,然后给别人来答题. 每个人都可以通过这个小程序系统出考题,然后给到别人答题(自己.同 ...

  10. 统考计算机模拟题及答案,全国统考计算机应用基础模拟题及答案.pdf

    全国统考计算机应用基础模拟题及答案.pdf 全国统考计算机应用基础模拟 题及答案 全国统考计算机应用基础模拟 题及答案 2013 年远程教育本科全国统考计算机应用基础模拟题 及答案( 7) 一.单选题 ...

最新文章

  1. 2019年大数据发展将走向何方
  2. 自己写的一个复杂查询
  3. 移动端调用百度地图api_百度智能云图像识别API调用
  4. 问:一行Python代码到底能干多少事情?(三)
  5. wxWidgets:wxDC类用法
  6. phpstudy+dvwa搭建
  7. Tensorflow图像编码处理
  8. fastText分类器
  9. .NET、ASP.NET控件及源码大汇总 最新最全哦
  10. java 动态转换器_非常简单的Java动态转换
  11. 《数据库系统基础教程》读书笔记——第一章 数据库系统世界
  12. 【深度】注册测绘师执业制度实施的现状分析
  13. Matlab 三角函数输入
  14. jq实现图片拖动滑块验证码
  15. K8S集群应用市场安装部署:第一篇
  16. 谷歌浏览器主页被挟持篡改2345www.dh012.com
  17. 三天流量有效期具体怎么算_飞猪不从APP提取出来流量有效期多久?如何提取?(含与客服对话)...
  18. 2018 新一代人工智能院士高峰论坛 总结文章
  19. OSChina 周二乱弹 ——现在我满眼都是小星星
  20. 分层抽样不按比例如何加权_按比例分层抽样和定额抽样的区别?

热门文章

  1. 系统自动化制作工资条,很简单,还能发送短信息
  2. mpdf配置自定义字体
  3. tif软件Android版下载,TIF文件查看器
  4. 升级ios13后,iPhone手机新增了截长屏功能,实用又方便
  5. 【转载】高斯滤波器详解
  6. Qt学习之Qt基础入门(上)
  7. mappedBy的基本认识
  8. 内存映射文件(专门读写大文件)
  9. Gcode G4及M603定义
  10. Unity 安装失败原因