分享一个爬取HUST(哈理工)学生成绩的Python程序(OCR自动识别验证码)
Python版本:3.5.2
日期:2018/1/21
__Author__ = "Lance#"
# -*- coding = utf-8 -*-
from urllib import request
from urllib import parse
from http import cookiejar
from aip.ocr import AipOcr
import re
class Hust(object):
def __init__(self, stu_id, passwd):
#登录地址,验证码地址,成绩查询地址
self.__url_check = "http://jwzx.hrbust.edu.cn/academic/getCaptcha.do"
self.__url_login = "http://jwzx.hrbust.edu.cn/academic/j_acegi_security_check"
self.__url_score = "http://jwzx.hrbust.edu.cn/academic/manager/score/studentOwnScore.do"
#信息头,模拟浏览器
self.__headers = {
"User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:57.0) Gecko/20100101 Firefox/57.0"
}
self.__captcha = ''
#这里是自已在AI中申请到的ID和KEY
self.__APP_ID = 'xxxxxx'
self.__API_KEY = 'xxxxxx'
self.__SECRET_KEY = 'xxxxxx'
#参数信息,在浏览器中可以捕获
self.__post_data = {
"groupId": "",
"j_username": stu_id,
"j_password": passwd,
"j_captcha" : ''
}
##声明一个CookieJar对象实例
self.__cookie = cookiejar.CookieJar()
#利用HTTPCookieProcessor对象来创建cookie处理器
self.__cookieProc = request.HTTPCookieProcessor(self.__cookie)
# 通过handler来构建opener
self.__opener = request.build_opener(self.__cookieProc)
#安装使用这个opener
request.install_opener(self.__opener)
def ocr_captcha(self):
'''ocr识别验证码'''
Req = request.Request(self.__url_check, headers=self.__headers)
captcha = request.urlopen(Req).read()
#AI的接口函数
client = AipOcr(self.__APP_ID, self.__API_KEY, self.__SECRET_KEY)
res = client.basicGeneral(captcha)
self.__captcha = res['words_result'][0]['words']
def get_captcha(self):
'''得到验证码'''
return self.__captcha
def set_postdata(self):
'''设置要发送的参数,就是修改验证码'''
self.__post_data["j_captcha"] = self.__captcha
def login(self):
'''模拟登录'''
#urlencode的作用:将字符串以URL编码,用于编码处理
data = parse.urlencode(self.__post_data).encode()
Req = request.Request(self.__url_login, headers=self.__headers)
html = request.urlopen(Req, data=data)
#登录页采用的是GBK编码,这个需要注意
return html.read().decode("GBK")
def get_score(self):
'''获取到成绩信息,并用正则分解'''
Req = request.Request(self.__url_score, headers=self.__headers)
res = request.urlopen(Req).read().decode()
#解析HTML采用的正则表达式
pat = re.compile('<td>(.*?)</td>', re.S)
list = re.findall(pat, res)
#对采集到的数据进行整理
for i, con in enumerate(list):
list[i] = con.replace("\n ", "")
return list
def display(self, list):
'''显示成绩信息'''
cnt = len(list)
new_list = []
cnt -= 3
y = int(cnt / 13)
for m in range(y):
new_list.insert(m, [list[j] for j in range(3 + m * 13, 16 + m * 13)])
print("学年 学期 及格标志 分数 学分 课程名")
for item in new_list:
print("{} {} {:>5s} {:5s} {:^5s} {:^20s}".format(
item[0], item[1], item[12], item[6].replace('<span style=" color:#FF0000">', "").replace("</span>", ""),
item[7], item[3]))
if __name__ == '__main__':
cnt = 1
err_str = "输入的验证码不正确!"
#此处是自己的学号和密码
stu = Hust("xxxxxx", "xxxxxx")
while True:
stu.ocr_captcha()
print("识别到的验证码为: %s ------ " % stu.get_captcha(), end="")
stu.set_postdata()
html = stu.login()
if err_str not in html:
print("验证码正确")
break
cnt += 1
print("验证码错误,启动第%d次识别" % cnt)
print()
print("Score Info".center(70, "-"))
list = stu.get_score()
stu.display(list)
print("End".center(70, "-"))
完成效果图:

请自动忽略这个人挂科的消息,0.0
分享一个爬取HUST(哈理工)学生成绩的Python程序(OCR自动识别验证码)的更多相关文章
- [W3bsafe]分享一个爬SQL注入漏洞的工具
分享一个爬SQL注入的工具 本文转自:i春秋社区由团队核心成员若间开发把工具放到E盘的一个文件夹 他会自动生成一个文本文件 Result.txt 最大页数 自己想弄填多少就填多少关键词 注入点关键词 ...
- php中CURL技术模拟登陆抓取数据实战,抓取某校教务处学生成绩。
这两天有基友要php中curl抓取教务处成绩的源码,用于微信公众平台的开发.下面笔者只好忍痛割爱了.php中CURL技术模拟登陆抓取数据实战,抓取沈阳工学院教务处学生成绩. 首先,教务处登录需要验证码 ...
- 用Python爬虫爬取广州大学教务系统的成绩(内网访问)
用Python爬虫爬取广州大学教务系统的成绩(内网访问) 在进行爬取前,首先要了解: 1.什么是CSS选择器? 每一条css样式定义由两部分组成,形式如下: [code] 选择器{样式} [/code ...
- 用Python实现一个爬取XX大学电费通知的小脚本
内容简要 1分析网站 2简单爬取 3进阶自定义爬取 4保存进数据库 学校基础设施太差,宿舍电量过低提醒虽然贴在楼下,但是作为低头一族,经常忘记看提醒导致宿舍酣战时突然黑屏,为了避免这种尴尬的场景以及强 ...
- 用WebCollector制作一个爬取《知乎》并进行问题精准抽取的爬虫(JAVA)
简单介绍: WebCollector是一个无须配置.便于二次开发的JAVA爬虫框架(内核),它提供精简的的API.仅仅需少量代码就可以实现一个功能强大的爬虫. 怎样将WebCollector导入项目请 ...
- 一个爬取Bing每日壁纸的python脚本
1. 背景 Bing搜索每天的背景图片有些比较适合做桌面,但是有的提供下载有的不提供下载.每天去点击下载又不太方便,所以第一次学习了一下python爬虫怎么写,写的很简单. 2. 相关技术 2.1 P ...
- 开源一个爬取redmine数据的测试报告系统
背景 软件测试的最后有一道比较繁琐的工作,就是编写测试报告.手写测试报告在数据统计和分析上面要耗费比较大的事件和精力.之前工作室使用mantis管理bug缺陷.公司有内部有个系统,可以直接从manti ...
- 一个爬取https和http通用的工具类(JDK自带的URL的用法)
今天在java爬取天猫的时候因为ssl报错,所以从网上找了一个可以爬取https和http通用的工具类.但是有的时候此工具类爬到的数据不全,此处不得不说python爬虫很厉害. package cn. ...
- 一个爬取lativ诚衣网站上模特穿搭图片的爬虫
show the code: [peter@localhost savvy]$ vi lativ.py # -*- coding:utf-8 -*- import requests,lxml,os f ...
随机推荐
- Notes : <Hands-on ML with Sklearn & TF> Chapter 7
.caret, .dropup > .btn > .caret { border-top-color: #000 !important; } .label { border: 1px so ...
- redis_哈希对象
redis哈希对象的底层编码有两种:ziplist.hashtable ziplist编码 当一个哈希键只包含少量kv对.且key和value都是小整数值.短字符串时,redis会使用压缩列表来做 z ...
- centos 安装部署zabbix
Zabbix_server初始安装部署 各模块要安装的模块 Server:server+nginx+mysql+php Agentd:agentd Proxy:proxy+mysql 1.准备环境: ...
- 设置MessageBox自动关闭
通过设置定时器,让定时器的Tick事件模拟往MessageBox发送一个Enter按钮代替用鼠标点击MessageBox上的确定按钮,来实现MessageBox的自动关闭,实现代码如下: System ...
- 安装PyQt5时缺少designer.exe的解决办法
学习PyQt框架的时候,看到了可以用可视化的方法搭建界面,好像ios的xib,但是安装完成pyqt5后怎么都找不designer.exe这个文件,于是查到了一下.发现了可以通过安装pip instal ...
- Android优化指南
Android系统中GC内存泄漏的原因 主动回收内存System.gc();.getruntime.runtime.gc 导致内存泄漏主要的原因是,申请了内存空间而忘记了释放.如果程序中存在对无用对象 ...
- 10. 面向holder编程、自动轮询
没有看过上一篇文章的话,建议先去阅读GooglePlay:9.代码抽取(adapter) 项目框架的搭建: 以后每个view都是holder BaseHolder public abstract cl ...
- Drools规则引擎入门指南(三)——使用Docker部署Workbench
其实本来我也是打算使用Tomcat来部署Workbench的,但是在网上看了几篇文章,超级繁琐的配置.各种版本.实在看不下去了索性就直接使用Docker来部署了.本次部署的版本是最新稳定版,对应dro ...
- Redis学习笔记之延时队列
目录 一.业务场景 二.Redis延时队列 一.业务场景 所谓延时队列就是延时的消息队列,下面说一下一些业务场景比较好理解 1.1 实践场景 订单支付失败,每隔一段时间提醒用户 用户并发量的情况,可以 ...
- mongo in和not in查询
执行语句 db.getCollection("A表").find( { id:{ $in:[1,2]} } ) 作用:查询A表中id字段等于1和等于2 的记录 改成 id:{ $ ...