本篇目标

1.模拟登录学生成绩管理系统

2.抓取本学期成绩界面

3.计算打印本学期成绩

1.URL的获取

先贴一个URL,让大家知道学校学生信息系统的网站构架,主页是http://jwxt.sdu.edu.cn:7890/zhxt_bks/zhxt_bks.html,用了frame,一个多么古老的而又任性的写法,我们点到登录界面,审查一下元素,先看看登录界面的URL是怎样的?看到了右侧的frame名称,src=”xk_login.html”,可以分析出完整的登录界面的网址为http://jwxt.sdu.edu.cn:7890/zhxt_bks/xk_login.html,点进去看看,用浏览器监听网络。

用猎豹浏览器,审查元素时会有一个网络的选项,如果大家用的Chrome,也有相对应的功能,Firefox需要装插件HttpFox,同样可以实现。

这个网络监听功能可以监听表单的传送以及请求头,响应头等等的信息。大家看到的是登录之后出现的信息以及NetWork监听,显示了hearders的详细信息。最主要的内容,我们可以发现有一个表单提交的过程,提交方式为POST,两个参数分别为stuid和pwd。

请求的URL为http://jwxt.sdu.edu.cn:7890/pls/wwwbks/bks_login2.login,没错,找到表单数据和目标地址就是这么简单。

在这里注意,刚才的 http://jwxt.sdu.edu.cn:7890/zhxt_bks/xk_login.html 只是登录界面的地址,刚刚得到的这个地址才是登录索要提交到的真正的URL。希望大家这里不要混淆。

不知道这个系统有没有做headers的检查,我们先不管这么多,先尝试一下模拟登录并保存。

2.模拟登录

通过以上信息,我们已经找到了登录的目标地址为 http://jwxt.sdu.edu.cn:7890/pls/wwwbks/bks_login2.login

有一个表单提交到这个URL,表单的两个内容分别为stuid和pwd,学号和密码,没有其他的隐藏信息,提交方式为POST。

现在我们首先构造以下代码来完成登录。看看会不会获取到登录之后的提示页面。

__author__ = 'CQC'

# -*- coding:utf-8 -*-

import urllib

import urllib2

import cookielib

import re

#山东大学绩点运算

class SDU:

def __init__(self):

self.loginUrl = 'http://jwxt.sdu.edu.cn:7890/pls/wwwbks/bks_login2.login'

self.cookies = cookielib.CookieJar()

self.postdata = urllib.urlencode({

'stuid':'201200131012',

'pwd':'xxxxxx'

})

self.opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(self.cookies))

def getPage(self):

request  = urllib2.Request(

url = self.loginUrl,

data = self.postdata)

result = self.opener.open(request)

#打印登录内容

print result.read().decode('gbk')

sdu = SDU()

sdu.getPage()

测试一下,竟然成功了,竟然没有做headers检查,很顺利就登录进去了。

说明一下,在这里我们利用了前面所说的cookie,用到了CookieJar这个对象来保存cookies,另外通过构建opener,利用open方法实现了登录。如果觉得这里有疑惑,请看爬虫入门六之Cookie的使用,这篇文章说得比较详细。

接下来我们只要再获取到本学期成绩界面然后把成绩抓取出来就好了。

3.抓取本学期成绩

让我们先在浏览器中找到本学期成绩界面,点击左边的本学期成绩。

重新审查元素,你会发现这个frame的src还是没有变,仍然是xk_login.html,引起这个页面变化的原因是在左边的本学期成绩这个超链接设置了一个目标frame,所以,那个页面就显示在右侧了。

所以,让我们再审查一下本学期成绩这个超链接的内容是什么

找到它了,本学期成绩

那么,完整的URL就是http://jwxt.sdu.edu.cn:7890/pls/wwwbks/bkscjcx.curscopre,好,URL已经找到了,我们继续完善一下代码,获取这个页面。

__author__ = 'CQC'

# -*- coding:utf-8 -*-

import urllib

import urllib2

import cookielib

import re

#山东大学绩点运算

class SDU:

def __init__(self):

#登录URL

self.loginUrl = 'http://jwxt.sdu.edu.cn:7890/pls/wwwbks/bks_login2.login'

#本学期成绩URL

self.gradeUrl = 'http://jwxt.sdu.edu.cn:7890/pls/wwwbks/bkscjcx.curscopre'

self.cookies = cookielib.CookieJar()

self.postdata = urllib.urlencode({

'stuid':'201200131012',

'pwd':'xxxxxx'

})

#构建opener

self.opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(self.cookies))

#获取本学期成绩页面

def getPage(self):

request  = urllib2.Request(

url = self.loginUrl,

data = self.postdata)

result = self.opener.open(request)

result = self.opener.open(self.gradeUrl)

#打印登录内容

print result.read().decode('gbk')

sdu = SDU()

sdu.getPage()

上面的代码,我们最主要的是增加了result = self.opener.open(self.gradeUrl)

这句代码,用原来的opener 访问一个本学期成绩的URL即可。

本学期成绩的页面已经被我们抓取下来了,接下来用正则表达式提取一下,然后计算学分即可

4.抓取有效信息

接下来我们就把页面内容提取一下,最主要的便是学分以及分数了。

平均绩点 = ∑(每科学分*每科分数)/总学分

所以我们把每科的学分以及分数抓取下来就好了,对于有些课打了良好或者优秀等级的,我们不进行抓取。

我们可以发现每一科都是TR标签,然后是一系列的td标签

0133201310

面向对象技术

1

2.5

20150112

94

必修

我们用下面的正则表达式进行提取即可,部分代码如下

page = self.getPage()

myItems = re.findall('

.*?(.*?).*?(.*?).*?',page,re.S)

for item in myItems:

self.credit.append(item[0].encode('gbk'))

self.grades.append(item[1].encode('gbk'))

主要利用了findall方法,这个方法在此就不多介绍了,前面我们已经用过多次了。

得到的学分和分数我们都用列表list进行存储,所以用了append方法,每获取到一个信息就把它加进去。

5.整理计算最后绩点

像上面那样把学分绩点都保存到列表list中了,所以我们最后用一个公式来计算学分绩点就好了,最后整理后的代码如下:

# -*- coding: utf-8 -*-

import urllib

import urllib2

import cookielib

import re

import string

#绩点运算

class SDU:

#类的初始化

def __init__(self):

#登录URL

self.loginUrl = 'http://jwxt.sdu.edu.cn:7890/pls/wwwbks/bks_login2.login'

#成绩URL

self.gradeUrl = 'http://jwxt.sdu.edu.cn:7890/pls/wwwbks/bkscjcx.curscopre'

#CookieJar对象

self.cookies = cookielib.CookieJar()

#表单数据

self.postdata = urllib.urlencode({

'stuid':'201200131012',

'pwd':'xxxxx'

})

#构建opener

self.opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(self.cookies))

#学分list

self.credit = []

#成绩list

self.grades = []

def getPage(self):

req  = urllib2.Request(

url = self.loginUrl,

data = self.postdata)

result = self.opener.open(req)

result = self.opener.open(self.gradeUrl)

#返回本学期成绩页面

return result.read().decode('gbk')

def getGrades(self):

#获得本学期成绩页面

page = self.getPage()

#正则匹配

myItems = re.findall('

.*?(.*?).*?(.*?).*?',page,re.S)

for item in myItems:

self.credit.append(item[0].encode('gbk'))

self.grades.append(item[1].encode('gbk'))

self.getGrade()

def getGrade(self):

#计算总绩点

sum = 0.0

weight = 0.0

for i in range(len(self.credit)):

if(self.grades[i].isdigit()):

sum += string.atof(self.credit[i])*string.atof(self.grades[i])

weight += string.atof(self.credit[i])

print u"本学期绩点为:",sum/weight

sdu = SDU()

sdu.getGrades()

好,最后就会打印输出本学期绩点是多少,最主要的了解上面的编程思路就好。

最主要的内容就是Cookie的使用,模拟登录的功能。

python绩点计算_Python爬虫实战(3):计算大学本学期绩点相关推荐

  1. python二手交易平台代码_PYTHON爬虫实战_垃圾佬闲鱼爬虫转转爬虫数据整合自用二手急速响应捡垃圾平台_3(附源码持续更新)...

    说明 文章首发于HURUWO的博客小站,本平台做同步备份发布. 如有浏览或访问异常图片加载失败或者相关疑问可前往原博客下评论浏览. 原文链接 PYTHON爬虫实战_垃圾佬闲鱼爬虫转转爬虫数据整合自用二 ...

  2. python爬取喜马拉雅_Python爬虫实战案例之爬取喜马拉雅音频数据详解

    这篇文章我们来讲一下在网站建设中,Python爬虫实战案例之爬取喜马拉雅音频数据详解.本文对大家进行网站开发设计工作或者学习都有一定帮助,下面让我们进入正文. 前言 喜马拉雅是专业的音频分享平台,汇集 ...

  3. python爬网易新闻_Python爬虫实战教程:爬取网易新闻;爬虫精选 高手技巧

    Python爬虫实战教程:爬取网易新闻:爬虫精选 高手技巧 发布时间:2020-02-21 17:42:43 前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有, ...

  4. python模拟登录网站_Python爬虫实战之(四)| 模拟登录京东商城

    作者:xiaoyu 微信公众号:Python数据科学 知乎:Python数据分析师 前两篇和大家分享了爬虫中http的一些概念和使用方法,基础篇我们主要介绍了http的请求头,高级篇我们主要介绍了co ...

  5. python 豆瓣评论数据分析_Python爬虫实战案例:豆瓣影评大数据分析报告之网页分析...

    个人希望,通过这个完整的爬虫案例(预计总共4篇短文),能够让爬虫小白学会怎么做爬虫的开发,所以在高手们看来,会有很多浅显的废话,如果觉得啰嗦,可以跳过一些内容~ 上一篇文章给大家简单介绍了Python ...

  6. python 爬网站 实例_python爬虫实战:之爬取京东商城实例教程!(含源代码)

    前言: 本文主要介绍的是利用python爬取京东商城的方法,文中介绍的非常详细,下面话不多说了,来看看详细的介绍吧. 主要工具 scrapy BeautifulSoup requests 分析步骤 1 ...

  7. python录音详解_Python爬虫实战案例:取喜马拉雅音频数据详解

    前言 喜马拉雅是专业的音频分享平台,汇集了有声小说,有声读物,有声书,FM电台,儿童睡前故事,相声小品,鬼故事等数亿条音频,我最喜欢听民间故事和德云社相声集,你呢? 今天带大家爬取喜马拉雅音频数据,一 ...

  8. python 12306抢票_Python爬虫实战:12306抢票开源!

    今天就和大家一起来讨论一下python实现12306余票查询(pycharm+python3.7),一起来感受一下python爬虫的简单实践 我们说先在浏览器中打开开发者工具(F12),尝试一次余票的 ...

  9. python成绩查询系统_Python爬虫实战:登录教务系统查成绩

    本文记录我用Python登录教务系统查询成绩的过程.手动输入验证码,简单获取成绩页面.后续将可能更新自动识别验证码登录查询 前期准备 本爬虫用到了Python的Requests库和BeautifulS ...

最新文章

  1. flask 检测post是否为空_用Flask和Vue制作一个单页应用(五)
  2. 跨链Cosmos(11) 消息结构
  3. VC++获取屏幕大小第三篇 物理大小GetDeviceCaps 下
  4. 用辩证、动态的眼光看世界
  5. 模拟实现顺序表ArrayList1(三级)
  6. Python heapq库的用法介绍
  7. 木兰编程语言重现:引用本地木兰模块;模拟凑十法加法
  8. matlab 引号内变量,MATLAB 7.0 单引号内变量现实问题!
  9. Nagios+Cacti模块——Nagios+Cacti 搭建及整合(一)
  10. 用Hough投票做物体检测的3篇文献
  11. Atitit 常见的树形结构 红黑树  二叉树   B树 B+树  Trie树 attilax理解与总结
  12. 如何弥补mac系统存在的局限性
  13. 回文数五位和六位c语言,特殊回文数
  14. 推荐给计算机专业教师读的书
  15. 静态路由(也许是目前最全的)
  16. 半次元cos图片爬虫
  17. 他把我撞了,却骂我diao丝
  18. Apple LZF算法解析
  19. 网络舆情分析-part1
  20. 中国天气网 天气预报API 国家气象局 根据城市名称抓取城市ID,XML格式、JSON格式、图片代码...

热门文章

  1. Scrolling DIV and Canvas flicker on iPhone/iPad touch
  2. 代码质量检测(jacoco pmd pipeline)
  3. nginx实现跨域访问
  4. vue fullCalendar的使用及扩展(支持农历显示及鼠标右键新建)
  5. gitlab ci/cd预设变量
  6. 河南慧萌自动化生成系统使用文档
  7. 3D 渲染过程:逼真的 3D 渲染的分步指南_棋盘格渲染
  8. 【经验分享】Error:‘for’ loop initial declarations are only allowed in C99 mode 的解决方案
  9. Calico — 架构
  10. 考博联系导师的办法[转]