网课邦

当前位置:首页 > 网课资讯

网课资讯

青书学堂自动刷课脚本软件下载-快速看完课程

时间:2025-04-12 16:24:08 作者:暂无作者 浏览量:
内容页左侧

简单的自动化使用–使用selenium实现学习通网站的刷慕课程序。注释空格加代码大概200行不到

环境Python3.6 + pycharm + chrom浏览器 + chromdriver

依赖库selenium,time,random

  • selenium实现自动化控制浏览器

  • time和random设置随机的停留时间,使程序更像是人类在控制。

基本思想:使用Python中的selenium库来控制chrom浏览器来刷慕课,而且是模拟人类点击物理,相当于物理外挂。

1.实现模拟登录,选择省份,学校,输入账号,密码,以及验证码。

  • 使用selenium库来定义一个chrom实例driver。

  • 使用driver来进入登录网址

  • 使用driver的find_element_by_xpath方法来选取省份,学校(这个因个人而不同的,程序里面是需要更改的。

下面界面的网址是:

1.1点击选择单位按钮,会出现各省份和个学校的列表


1.2.右击你所在的省份,点击检查(这里以河南的洛阳理工为例),右侧光标会定位在你所在省份的标签列,


1.3.右击标签–>copy—>copy xpath


1.4.把copy之后的代码复制到从github下载下来的第十四行代码中,即

 点击河南henan = driver.find_element_by_xpath(&9;要复制的地方&9;)henan.click()

1.5.选择学校,点击左侧列表中的河南,在右侧找到你所在的学校,右击学校点击检查


1.6.在右侧会光标会显示在你所在学校的标签中,右击—>copy–>copy xpath


1.7把复制的代码粘贴到从github下载下来的第22行

 点击洛阳理工louyang = driver.find_element_by_xpath(&9;要复制的地方&9;)louyang.click()

1.8接下来还要修改的代码部分是刷的那个慕课的网址,请确保是下面这个图中的url链接


1.9把整个url复制下来之后要替换的是从github下载下来的代码中的第45行代码,把url复制到下面要替换的位置

 得到慕课网址get_url = &9;要替换的地方网址&9;driver.get(get_url)time.sleep(5)

2.接下来就是运行程序,输入自己的账号密码和网页中的验证码。程序就能跑起来了,就能实现物理外挂来刷课。

如果只是想使用这个程序的话,上面的就已经够用了。下载github代码,修改省份,学校,和慕课网址运行程序就能开启物理外挂来刷慕课了。如果想和我一起来维护这个程序的话,可以看下面的讲解,进一步了解这一程序的运行原理。

3.接下来就是重点,程序实现的原理。首先获取一共有多少个章节,遍历章节,处理网络不稳定,换公网,点击播放按钮,处理答题细节,处理打完题的情况。

3.0 播放器的html代码是在页面下面的ifram中的ifram中的hml代码里面要使用driver的switch_to.frame方法来切换到ifram中去。

  • 代码处理

 切换到下面的iframe里try:driver.switch_to.frame(driver.find_element_by_xpath(&9;//body/div/div/p/div/iframe&9;))except:driver.switch_to.frame(driver.find_element_by_xpath(&9;//body/div/div/p/span/div/iframe&9;))

3.1找到所有的章节标签遍历。

  • 所有的章节都在//[@id=“coursetree”]/div里面,使用driver的find_elements_by_xpath方法来找到所有标签,获取标签数量,并遍历


  • 3.1从html代码中发现每一个大章节的第一个标签和其他标签不一样,第一章节是在//[@id=“coursetree”]/div/div中,而下面的章节是在//[@id=“coursetree”]/div中比第一章节少了一个div。可以使用try-except语句来处理先获取点击第一章节或第二章节的标签,出现异常再点击另一个按钮,这个方法可以圆满的处理遍历章节中使每一个都可以遍历到

  • 下面是章节不一样的图

  • 下面是处理的代码

 点击章节try:driver.find_element_by_xpath(&9;//[@id="coursetree"]/div[&9; + str(i + 1) + &9;]&9;).click()except:driver.find_element_by_xpath(&9;//[@id="coursetree"]/div[&9; + str(i + 1) + &9;]/div&9;).click()

  • 1

  • 2

  • 3

  • 4

  • 5

3.2点击播放按钮,播放按钮到目前位置发现有两种一种是直接在视频框里面的,另一种要先点击视频切换到视频框,在点击播放按钮。

  • 下面是第一种情况直接就能点击播放按钮

  • 下面是第二种情况,要先点视频,再点击播放按钮

  • 下面是处理这两种情况的处理逻辑

 找到播放按钮并点击try:button = driver.find_element_by_xpath(&9;//[@id="reader"]&9;)button.click()except:driver.find_element_by_xpath(&9;//[@id="dct2"]&9;).click()driver.find_element_by_xpath(&9;//[@id="reader"]&9;).click()

    3.3处理网络问题,有时候使用本校的网是不行的,会出现网络不佳的问题,所有要使用代码来直接切换到公网按钮,使用代码先点击本校按钮,再点击公网2按钮(直接点击公网2按钮是不行的,实验过了,这些点击的按钮的位置都是通过find_element_by_xpath来获取的,和上面方法一样不在多说。)

    • 下面是实现代码

     找到公网try:driver.find_element_by_xpath(&9;//[@id="video"]/div[4]/div[8]/span&9;).click()driver.find_element_by_xpath(&9;//[@id="video"]/div[4]/div[8]/div/ul/li[3]/span[1]&9;).click()except:pass

      3.4像找到快进按钮啊,静音按钮都是一个办法的。通过find_element_by_xpath方法得到并点击。

      4.下面处理答题,完成视频,和网络不佳的情况。这些逻辑但是在try-except里面处理的

      4.1出现网络不佳时,使用右击—>检查---->右击copy---->copy xpath来获取公网2的标签位置并点击。

       当网络不可用时点击公网try:driver.find_element_by_xpath(&9;//[@id="vjserrdisplay-1035"]/ul/li[2]/label&9;).click()except:pass

        4.2出现答题时找到,视频中答题位置,找到选择题选项位置,遍历每一个选项点击,总有一个是正确的(而且这个答案是不影响总成绩的)
        -代码实现

         找到视频中出现的答题位置if driver.find_element_by_xpath(&9;//body/div[4]/div/div[7]/span/div/div&9;): 找到选择题button3 = driver.find_elements_by_xpath(&9;//body/div[4]/div/div[7]/span/div/div/ul/li&9;) print("button3{}", button3)while driver.find_element_by_xpath(&9;//body/div[4]/div/div[7]/span/div/div&9;): print(1) 对选项进行遍历for button1 in button3:button1 = button1.find_element_by_xpath(&9;label&9;) print("button1{}", button1)button1.click()time.sleep(random.random()3) 点击提交按钮button5 = driver.find_element_by_xpath(&9;//body/div[4]/div/div[7]/span/div/div/div[2]&9;) print("button5{}", button5)button5.click()time.sleep(random.random()3)if driver.switch_to.alert():al = driver.switch_to.alert()al.accept()time.sleep(random.random())if not driver.find_element_by_xpath(&9;//body/div[4]/div/div[7]/span/div/div&9;): print("答题完成")breakexcept Exception as e: print("未找到答题位置")time.sleep(random.random()3)

        4.3判断视频是否看完,找到播放标签,如果播放标签的文本是‘重播’那么证明这个视频已经完成。跳出循环就好。

        • 代码实现

        try: 找到重播按钮rename = driver.find_element_by_xpath(&9;//[@id="video"]/div[4]/button[1]&9;).get_attribute(&9;title&9;)if rename == &9;重播&9;:breakexcept Exception as e:time.sleep(random.random()3)

          5返回上一层ifram的上一层ifram继续下一层 循环。

          代码的不足之处:

          -暂时不会判断视频是否播放过。

          • 有一条输出语句中时间标签获取不出来。

          • 播放时必须有一台电脑在运行程序,而且鼠标从页面出去,或者不进入到页面中,不然会造成暂停异常。(如果你有一台云主机的话,那就圆满了)

          运行结果:部分截图

          从运行原理来看应该不会被封的,因为是模仿人类点击,中间设置了大量的time.sleep()而且还是随机的时间毫无规律。