学校要求登录教务处网站做一个测试题,我做了看了看,30分钟300道题,240分几个,题量不少,题还不好做。研究了一下发现原来在网站上就有题库的,但是一道题只有6s 的时间作答,边查边做肯定是时间不够的。灵光一闪,人生苦短,我用Python,写个自动答题的机器人吧。


思路:

  • 爬取题库并存储到数据库
  • 模拟登录教务系统
  • 进入答题页面,遍历题目,匹配数据库中记录,给出答案
  • 提交数据

用到的工具:

  • Python
  • requests
  • BeautifulSoup
  • mongodb

实现过程:

  • 模拟登录

以前研究过学校教务系统的登录,现在终于在正事上排上用场了。学校教务系统的登录还算简单,没有验证码,唯一一点儿小障碍是登录表单会有几个隐藏字段,有个字段会动态改变,解决就是先GET一下登录网址,获取这几个字段的值,再随表单进行POST。代码:

import requests
from bs4 import BeautifulSoup
import osheaders = {'Connection': 'keep-alive','Cache-Control': 'max-age=0','Upgrade-Insecure-Requests': '1','User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.95 Safari/537.36','Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8','Accept-Encoding': 'gzip, deflate, sdch','Accept-Language': 'zh-CN,zh;q=0.8,en;q=0.6,zh-TW;q=0.4'
}session = requests.session()# 先GET一下登录页面获得隐藏字段
resp = session.get("http://ids.qfnu.edu.cn/authserver/login?service=http%3A%2F%2F202.194.188.19%2Fcaslogin.jsp", headers=headers)
bsObj = BeautifulSoup(resp.text, "html.parser")
lt = bsObj.find('input', {'name':'lt'})['value']
execution = bsObj.find('input', {'name':'execution'})['value']params = {'username': os.environ.get('STU_ID'),   # 环境变量获取的学号'password': os.environ.get('STU_PWD'), # 环境变量获取的密码'lt': lt,'execution': execution,'_eventId': 'submit','rmShown': '1'
}# post 数据登录成功
resp = session.post("http://ids.qfnu.edu.cn/authserver/login?service=http%3A%2F%2F202.194.188.19%2Fcaslogin.jsp", data=params, headers=headers)
  • 题库爬取

用了Python的requests库进行页面的爬取,励志小哥写的这个库的确好用,特别是运用 requests.session()之后,处理好登录之后,再也不用管那些烦人的cookie 啥的了,用了BeautifulSoup来进行页面解析,用起来也是很顺手。开始有乱码,一看网页编码是gb2312的,稍微设置一下也OK了。
内容有了,当然要存储起来了,不然每次答题都有爬题库多麻烦,何况是些千年不变的东西。开始用的是MySQL,然而编码问题让人头疼,设置编码为gb2312,存储的时候说有内容 gb2312 又解析不了,于是程序就挂了。搞了很长时间也没搞定,还把我的 Sequel Pro 给搞挂了,f***!
静下心来一想,题库只要写数据库写一遍就OK了,但是答题的时候会频繁地查询数据库,用nosql数据库多好。题目做键,答案做值就行了。看过redis,但毕竟是内存型数据库,虽然快,但是还要做持久化,直接用mongodb吧,还没看过,刚好学习了,边学边用。
爬取并存储题库部分的代码:

tikubhs = [8692, 10988, 10989, 10990, 10991, 10992, 10993, 10994, 10995]  # 每一类题库的编号
pages = [153, 77, 13, 18, 22, 27, 10, 39, 12]  # 每一个题库的题目页数from pymongo import MongoClient
client = MongoClient()
db = client.shitiDB    # 数据库名 shitiDBshiti_table = db.shitis    # 表名 shitisfor tikubh, page_range in zip(tikubhs, pages):for page in range(1, page_range+1):url = "http://aqjy.qfnu.edu.cn/redir.php?catalog_id=6&cmd=learning&tikubh="+str(tikubh)+"&page="+str(page)resp = session.get(url)resp.encoding = 'gb2312'bsObj = BeautifulSoup(resp.text, "html.parser")shitis = bsObj.find_all('div', class_='shiti')daans = bsObj.find_all('span', style='color:#666666')values = []for timu_str, daan_str in zip(shitis, daans):shitibh = int(timu_str.h3.text[0:5])timu = timu_str.h3.text[6:]daan = daan_str.text[daan_str.text.find('标准答案')+5:].strip(' )')d = {'shitibh':shitibh, 'tikubh':tikubh, 'timu':timu, 'daan':daan}values.append(d)new_result = shiti_table.insert_many(values)
  • 模拟作答

这一部分是最关键的部分,再这上面的耗时比较多,大部分时间都在研究他的数据的提交流程。
题目是分页的,且选择页面或点击上下页的时候,地址栏的地址是不变的,说明分页是通过js实现的,而不是直接用的链接:

研究得知,上下页和页面选择都是通过post数据标志到本页面实现的

搞懂了这些数据的意义和他们之间的关系,用代码模拟出来就OK了,当作到最后一页完成的时候,把tijiao标志也设为1,POST到原URL就完成了作答,这部分代码就不贴了,文末有GitHub链接。

  • 可能的改进  写好之后许多同学找我给答题,看看如果多的话用flask搭成个web服务。高效还不用担心我泄露你们的密码了。爬题库的时候想的是爬答案的文本,爬成了ABCD的选项,多亏选项和答案文本的对应关系没变,但也造成个别问题答案会有错误,致使我给答题的同学分数基本都在297-299之间(满分300分),少有300分的同学。本来想改来着,转念一想都满分也不太好,有点误差也好,可能这部分不会改了,感兴趣的可以自己改改看。

ps: 本校的可以直接搭好拿来用就可以了,其他同学如有类似需求,这个系统是某公司开发的,好多学校都在用,folk一份改改应该也没问题。

考试系统自动答题,你还在为不及格烦恼么?相关推荐

  1. python答题系统的代码_Python考试系统自动答题(教务处)

    要求 某学校要求登录教务处网站 做一个测试题 30分钟300道题,240分几个,题量不少,题还不好做. 研究发现原来在网站上有题库 但是一道题只有6s 的时间作答 边查边做时间不够 人生苦短,何不Py ...

  2. 在线考试系统学员答题批改日志,实战练习

    一.环境要求 Hadoop+Hive+Spark+HBase 开发环境 三.数据描述 这是一份来自于某在线考试系统的学员答题批改日志,日志中记录了日志生成时间,题目 难度系数,题目所属的知识点 ID, ...

  3. 基于mysql的应用程序设计[j] 兰旭辉_熊家军_邓刚_高校C语言自动考试系统参考文献...

    [1]青宪,叶雪梅,陈钟,刘红. 无纸化考试系统自动组卷策略分析及改进[J]. 计算机应用,2008,28(S2):100-102. [2]王瑞金,段会川,Martin Gogolla. 统一建模语言 ...

  4. 开源~~~~spring boot +vue 前后端分离 在线考试系统 加自动组卷!!!!

    在线考试系统+自动组卷!!! springboot +vue 前后端分离系统 想要源码的可以B站搜索 技术小余哥

  5. c语言课程设计自动答题系统,C语言课程设计-单项选择题标准化考试系统设计.doc...

    PAGE 沈阳航空航天大学 课 程 设 计 报 告 课程设计名称:C语言课程设计 课程设计题目:单项选择题标准化考试系统设计 院(系): 计算机学院 专 业: 计算机科学与技术 班 级: 学 号: 姓 ...

  6. 计算机考试答题设计用例图,学生网上考试系统的设计与实现

    摘 要: 运用Visual C++程序设计技术与SQL Server2000数据库技术相结合,开发了学生网上考试系统.根据学生考试的特点和学校的实际情况,网上考试系统中设置两种用户,分别是学生和教师. ...

  7. 用计算机获取机读卡是通过什么实现的,一种基于图像识别技术的答题卡及考试系统的制作方法...

    本发明涉及智能考试系统. 背景技术: 传统答题卡具有如下缺陷: 1.答题卡定位需要右侧和底端的黑点来实现定位整张答题卡的行和列: 2.需要专用答题卡识别机(专有硬件)来识别答案: 3.需要用特种铅笔( ...

  8. 万维考试系统python_万维考试系统客户端下载|万维自动考试系统下载 v1.0 官方版_最火软件站...

    万维自动考试系统是北京万维捷通软件技术有限公司自主研发的一款专业的自动考试软件,能够满足各大高校的考试需要.用户可以是基于学生号或准考证号登陆平台.具备自动评分.在线出题.图库管理等功能,软件简单实用 ...

  9. 考试自动评分系统C语言改错,谈C语言上机考试的自动评分

    论文写作指导:请加QQ229366758 摘要:在程序设计课的上机考试系统中,如何实现自动评分是最为关键的部分.该文对不同题型给出了不同的评分方法,其中编程题的评分,采用学生答案和标准答案之间的编辑距 ...

最新文章

  1. C#生成的图片无法在ps中打开
  2. AIX 操作系统日常维护须知
  3. Maven配置将war包部署到Tomcat(tomcat7-maven-plugin)
  4. 1.多彩的幕布CCLayerColor,CCLayerGradient
  5. 【Linux】一步一步学Linux——bunzip2命令(66)
  6. java学习笔记(3)——面向对象
  7. 四天人工智能 python入门体验课_百度深度学习7天打卡营,用Python+AI识别“青你2”小姐姐的高颜值...
  8. 7-50 畅通工程之局部最小花费问题 (35 分)(思路加详解)来呀兄弟们冲呀呀呀呀呀呀呀
  9. Linux查看tar实用程序,linux tar指令常用选项
  10. YAML文件结构简介
  11. Android之ViewPager中包含ViewFlipper时实现双滑动嵌套解决父控件干扰问题
  12. 巧用编辑器正则表达式,批量修改删除超链接
  13. 设计模式(六)原型模式
  14. 关于5G你所需要知道的一切
  15. Windows下FireFox插件dll文件名,必须是np开头,不能是plugin结尾
  16. Centos7.0下MySQL的安装
  17. 【typecho插件】typecho邮箱插件LoveXiaozhou是一款Typecho邮件通知类插件、小周
  18. java mset_调用java jredis mset方法异常
  19. 在直流电源(Vcc)和地之间并接电容的作用
  20. Arm 架构的过程调用标准

热门文章

  1. input边框怎么去掉
  2. Android 8遇到的问题cat: /system/build.prop: Permission denied,如果不root,有方法解决吗?
  3. 碳基计算机电路,碳基CMOS集成电路技术
  4. donet还是java
  5. Neodynamic JSPrintManager for Blazor
  6. A代表数字1,B代表数字2,以此类推Z代表26
  7. MySQL服务无法启动咋办?
  8. angular aot编译报错 ERROR in ./src/main.ts 解决方法
  9. Gram矩阵+Gram矩阵和协方差矩阵的关系
  10. 华为诺亚方舟实验室招聘AI研究实习生