利用python完成大学刷课(从0到完成的思路)

栏目: Python · 发布时间: 5年前

内容简介:最近刚刚开学,学校总是有很多让人无语的课要修,还不能不修。然后我想写一个自动修课的脚本。大佬们不要笑我 是边面向百度学selenium边写脚本的 然后踩了一些坑 记录一下先放最终效果视频然后剩下就是脚本的思路 首先要获取课程的链接 然后打开以后执行js  finishWxCourse() 后来发现requests不是很好的能执行js 然后我就听从了几个师傅的意见用selenium...所以是边学边写的 遇到了几个小坑记一记

利用python selenium模块实现全自动化大学刷课

最近刚刚开学,学校总是有很多让人无语的课要修,还不能不修。然后我想写一个自动修课的脚本。大佬们不要笑我 是边面向百度学selenium边写脚本的 然后踩了一些坑 记录一下

先放最终效果视频

PS:室友在打lol说看见中单 不是说我哈 哈哈哈哈

http://ow2cltt3t.bkt.clouddn.com/15d3ed600eb39af4d80c4a49088b5c06.mp4

0x01:

首先分析一下它是怎么验证你看完这个课的。

利用 <a href='https://www.codercto.com/topics/20097.html'>python</a> 完成大学刷课(从0到完成的思路)

当学习完成时会发出这个请求

利用python完成大学刷课(从0到完成的思路)

然后看看这几个请求的数据都是在前端哪里生成的

利用python完成大学刷课(从0到完成的思路)

一番寻找就看到了是wx.js下的function finishWxCourse()  。控制台执行 finishWxCourse() 果然会发起完成修课的请求

利用python完成大学刷课(从0到完成的思路)

0x02:

然后剩下就是脚本的思路 首先要获取课程的链接 然后打开以后执行js  finishWxCourse() 后来发现requests不是很好的能执行js 然后我就听从了几个师傅的意见用selenium...所以是边学边写的 遇到了几个小坑记一记

安装不表 网上很多教程 chromedriver装在环境变量里面就好了 比如python的环境变量 如果遇到问题可以留言评论

先说一下 代码最终的整体思路是 打开网站----设置cookie----然后通过点击打开所有的隐藏元素-----定位点击----后退---------------点击打开所有的隐藏元素-------定位点击----------后退..然后重复之前的步骤

这是简单的启动浏览器和发起请求

        driver = webdriver.Chrome("C:/Python27/chromedriver.exe")
        driver.get("http://wb.mycourse.cn/")

删除所有的cookie并设置cookie。我是手动登陆然后再添加    有一个要记住的就是先要请求一次网页 才能设置cookie 再请求网页

driver.add_cookie({'name':'JSESSIONID','value':'93BEC0FDEF428F98DA1F69A6B3C2BF88'})  #已经过期的了 师傅们
driver.add_cookie({'name':'acw_tc','value':'7b39758715392684428742395e7ed4b94ed4e9616cb11d4b9df9e244ec7573'})        
driver.add_cookie({'name':'SERVERID','value':'02cc313090e3650844ab417ac43bf774|1539357767|1539357719'})
driver.get("http://wb.mycourse.cn/svnweiban/student/study_studyAndTest.action")

接着就是定位元素了 首先要看到我们要点击的课程链接

利用python完成大学刷课(从0到完成的思路)

看到class属性 有一个坑就是这里多个class属性 不能直接多个class一起定位 不然会找到 如果全部一起定位要用css寻找并且用.来链接 然后我这里用的是 courseLink定位 这个名字也很明显是做什么的。然后我也发现是98个课程都能定位到  前面几个class能定位到1000多个

link2s = driver.find_elements_by_class_name("courseLink")

我原本就很开心的以为差不多做完了准备写出一个这样子的代码

        for i in range(99):
                link2s = driver.find_elements_by_class_name("courseText")
                link2s[i].click()
                driver.execute_script("finishWxCourse()")

但是结果发现无法获取到元素 什么鬼 然后一直报错···苦苦百度以后发现···原来是 没有展开元素 是diplay:none。 隐藏了 然后我百度以后找到的方法一直是 通过执行js把none改为block结果发现不好定位啊

利用python完成大学刷课(从0到完成的思路)

<div class="widthPercent100 paddingL_30 border-box displayNone" style="transition: all 0.5s ease 0s; display: none;">

class属性都是不唯一的 然后很蛋疼 后来师傅推荐说通过xpath定位 可是好多个 不想嫌弃麻烦 洗了个澡回来以后发现可以 通过定位元素 然后点击元素 来实现自动展开列表

通过 前面截图的cursorPointer 能够成功定位20多个地方出来 但是前面几个定位是什么首页 搜索 不是我们想要的 问题不大。我们删除这几个定位就好了

blockclass = driver.find_elements_by_class_name("cursorPointer")
        del blockclass[0]
        del blockclass[0]
        del blockclass[0]
        for blockc in blockclass:
                blockc.click()

删除几个定位就好了

然后现在调试以后 集合代码跑了一次发现了几个问题,第一个就是 当

driver.execute_script("finishWxCourse()")    #执行js代码

执行代码以后,会alert一个窗口出来说 完成了课程。然后就会导致selenium不能点后退 面向百度编程以后

  dig_alert = driver.switch_to.alert     #搜索弹窗
        dig_alert.accept()                     #点击确定

接着就是最后一个坑了 driver.back() 以后蛋疼了 back以后 之前定位的会失效···所以只能每回退一次重新定位  还有要注意的就是在 一些关键地方之前要time sleep一秒 不然还没请求完成出来就执行下一步 了 会导致报错 最后就大功告成了


以上所述就是小编给大家介绍的《利用python完成大学刷课(从0到完成的思路)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

打造Facebook

打造Facebook

王淮、祝文让 / 印刷工业出版社 / 2013-2-1 / 39.80元

《打造Facebook》新书发布会,王淮与读者面对面,活动链接:http://www.douban.com/event/18166913/ 这本书的书名——《打造Facebook:亲历Facebook爆发的5年》很嚣张,谁有资格可以说这句话呢,当然,扎克伯格最有资格,但他不会亲自来告诉你,至少从目前的情况来看,近几年都不大可能。而且,这不是一个人的公司。里面的每一人,尤其是工程师,既是公司文......一起来看看 《打造Facebook》 这本书的介绍吧!

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具